- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
问题是找到使所有节点都为零所需的最小值,我们称之为 K。
给出了一个非二叉树。
在第一步中,您可以选择一个节点作为起点。如果 K 大于该节点的值,则将该值更改为零,并增加距离为一或两个的其他节点的值。请注意,一旦节点的值变为零,它就不会再递增,也不会允许与其相连的节点递增。
然后选择距离为1且至少有一个零值节点的另一个节点,重复该过程
5
\
2
\
5
当我们从值为 5 的叶子开始时,我们有
6
\
3
\
0
那么我们应该选择3;我们不能选择 6,因为它在距离 1 中没有零节点!
7
\
0
\
0
最后我们选择 7 并且 K = 7 但如果我们一开始选择 2 那么我们有:
6
\
0
\
6
那么我们应该选择6;因为值为 2 的节点现在为零,所以连接被切断,并且通过更改值为 6 的节点的值,不会再发生增量!
0
\
0
\
6
所以最小 K = 6
找到最大节点并从它开始(如果有多个最大节点,则选择较早出现的节点)
我定义了一个数组,我们称之为可能的节点,并将在第 1 步中找到的节点添加到它。
虽然 possible nodes 不为空,但我执行以下步骤:
一个。选择可能节点中的最大值;我们称它为max_node
使 max_node 幂为零并更新 K
增加其 parent 、祖 parent 、子女、孙子女和 sibling 的值(value)(如果他们之前不为零)
将具有非零值的父节点和子节点添加到可能的节点
从可能的节点
其实这是一道作业题,但这种做法不对!它会给出错误的答案并达到超时限制。
节点数≤3×105
-109 ≤ 节点值≤ 109
时间限制:2.5 秒
内存限制:256 MB
最佳答案
如果你从树中的一个随机节点开始,那么 K 是以下项中的最大值:
这是因为你只能选择与它相邻的 0 节点的节点并且这些节点不会递增。
我们可以得出结论,Kmin 必须介于 max 和 max + 2 之间。
所以 O(n) 算法可能如下所示:
max
并计算有多少节点具有该值 => maxCount
maxCount = 1
然后计算有多少节点具有值 max - 1
=> max1Count
,有两种可能性:
max1Count = 0
或值为 max - 1
的节点与值为 max
的节点的相邻节点数等于 max1Count
=> 解是max
max + 1
max
值的所有节点:
max
的深度只有一个节点:
max
的 child 的数量等于 maxCount - 1
=> 解决方案是 max + 1
max
的 child ,其值为 max
的 child 的数量等于 maxCount - 2
=>解决方案也是 max + 1
max
的 child ,但有 maxCount - 1
个孙子,它们都具有相同的父级和值 max
=>解决方案也是 max + 1
max + 2
maxCount
个节点并且它们都有相同的父节点 => 解决方案是 max + 1
max + 2
关于algorithm - 通过在每一步递增相邻节点来找到使所有树节点为零所需的最小值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55369154/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!