- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我尝试用谷歌搜索这个问题,但没有成功......我确信这个问题或类似问题有一个技术名称,但我似乎找不到答案。
给定一个整数列表 L
,先严格递增,然后严格递减,找出该列表的最大值和最小值。
例如,L
可能是 {1 2 3 4 5 4 3 2}
或 {2 4 5 7 3}
。
为了找到最小值,我说过最小的整数必须是左端点或右端点,所以只需比较端点,并返回最小的那个,给出常数时间。
为了找到最大值,我建议基本上使用递归二分搜索来找到点 L[x]
使得 L[x] > L[x-1]
和 L[x] > L[x+1]
,给出分摊的 lg(n) 时间。他似乎不喜欢这个答案,而且我觉得这个答案确实很幼稚,所以我想知道我是否遗漏了什么。
感谢您的帮助!
编辑:
我在 python 中的解决方案:
def Max(L):
n = len(L)-1
if n == 0:
return L[0]
if L[n/2] > L[n/2 - 1] and L[n/2] > L[n/2 + 1]:
return L[n/2]
elif L[n/2] < L[n/2 + 1]:
return Max(L[n/2:])
else:
return Max(L[:n/2])
最佳答案
好吧,查了一下,你有两个选择。更简单的是 ternary search.它的基本要点是,您找到通过的两个数字 1/3 (x) 和 2/3 (y)。如果 x < y,则最大值不能在前三分之一。如果 x > y,则不能在最后三分之一。将它与对基本情况的简单检查相结合,您就拥有了一个递归算法。
现在,它仍然是 O(log(n)),所以每次调用有一半的比较,但只有 2/3 的消除,你真的从 2*log(base 2)(n) 比较到 2 *log(base 3)(n) 比较。从理论上讲,它们是等价的。实际上,您获得的 yield 并不多,除非您没有随机访问权限,例如,对于某个功能。
更复杂的是Fibonacci search.另见 here.它类似于三元搜索,除了不只是选择 1/3 和 2/3 作为你的断点,还有一个涉及斐波那契数的整个奇特过程。它仍然是 O(log(n)),因此除非您没有直接的随机访问,否则可能不值得为实现而头疼。
关于algorithm - 找到先增加后减少列表的最大值和最小值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6798296/
几个月前,我做了一个功能,我的应用程序正在等待用户文档并做出相应的响应。直到我对项目进行优化并将其更新到最新版本之前,它一直是一种魅力。 如果存在用户文档,则流将产生该文档并关闭该流。 如果云Fire
Stack Overflow 有几个 examples其中函数首先获得可升级锁,然后通过升级获得独占访问。我的理解是,如果不小心使用,这可能会导致死锁,因为两个线程可能都获得了可升级/共享锁,然后都尝
这个问题在这里已经有了答案: MVC 4 Code First ForeignKeyAttribute on property ... on type ... is not valid (1 个回答
以下是部分代码。我需要在 finally 子句中关闭资源。我需要先调用 closeEntry() 还是 close()?我收到一些错误消息。 Error closing the zipoutjava.
我想使用 RxJS-DOM 观察 mousewheel 事件,这样当第一个事件触发时,我转发它然后删除所有值,直到后续值之间的延迟超过先前指定的持续时间。 我想象的运算符可能看起来像: Rx.DOM.
版本似乎与安装的不同。 我在 npm install 上收到警告 我将二进制文件安装到我的家庭/开发目录中,但它不适用于 sudo。所以我安装了apt。 (注意:我并没有真正安装,我提取并将路径放在/
我正在尝试展示 GAN 网络在某些指定时期的结果。打印当前结果的功能以前与 TF 一起使用。我需要换成 pytorch。 def show_result(G_net, z_, num_epoch, s
我是一名优秀的程序员,十分优秀!