- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
推理:我试图在 Python 中实现类似于 git bisect
的东西,但基本上是一个目录列表。
我有一个(长)版本号列表,如下所示:['1.0', '1.14', '2.3', '3.1', '4']
我有一个函数 works()
,它接受一个版本号,并返回一个值。
[works(x) for x in my_list]
看起来像:['foo', 'foo', 'foo', 'bar', 'bar']
...但是运行 works()
非常昂贵。
我想进行某种平分,以找到变化边界。
最佳答案
您可以简单地使用二进制搜索:
def binary_f(f,list):
frm = 0
to = len(list)
while frm < to:
mid = (frm+to)>>1
if f(list[mid]):
to = mid
else:
frm = mid+1
return frm
它将返回 第一个索引 i
bool(f(list[i]))
为 True
.
当然,该函数假定 list
上 f
的映射具有以下形式:
f(list) == [False,False,...,False,True,True,...,True]
如果不是这种情况,它通常会找到一个 swap 但哪个是未定义的。
假设 f
只是“版本为 2 或更高”,所以 lambda v:v >= '2'
,那么它将返回:
>>> binary_f(lambda v:v >= '2',['1.0', '1.14', '2.3', '3.1', '4'])
2
所以索引2
。如果整个列表返回 False
对象,它将**返回 len(list)
。因为它“假定”列表之外的元素将被评估为 True
:
>>> binary_f(lambda v:v >= '4.2',['1.0', '1.14', '2.3', '3.1', '4'])
5
当然在您的示例中 f
是 works
。
实验:
>>> binary_f(lambda v:v >= '2',['1.0', '1.14', '2.3', '3.1', '4'])
2
>>> binary_f(lambda v:v >= '0',['1.0', '1.14', '2.3', '3.1', '4'])
0
>>> binary_f(lambda v:v >= '1',['1.0', '1.14', '2.3', '3.1', '4'])
0
>>> binary_f(lambda v:v >= '1.13',['1.0', '1.14', '2.3', '3.1', '4'])
1
>>> binary_f(lambda v:v >= '2.4',['1.0', '1.14', '2.3', '3.1', '4'])
3
>>> binary_f(lambda v:v >= '3',['1.0', '1.14', '2.3', '3.1', '4'])
3
>>> binary_f(lambda v:v >= '3.2',['1.0', '1.14', '2.3', '3.1', '4'])
4
>>> binary_f(lambda v:v >= '4.2',['1.0', '1.14', '2.3', '3.1', '4'])
5
(我在这里当然做了一个非常便宜的版本检查,但它当然适用于更复杂的谓词)。
由于这是二分搜索,它将在 O(log n) 中运行,n 是列表中的项目数,而线性搜索可以 结果 O(n) 检查(通常更昂贵)。
编辑:如果列表包含两个值并且您想找到交换,您可以简单地先计算索引0
:
val0 = f(list[0])
然后提供binary_f
:
binary_f(lambda v:works(v) != val0,list)
或者把它放到一个很好的函数中:
def binary_f_val(f,list):
val0 = f(list[0])
return binary_f(lambda x:f(x) != val0,list)
关于python - 使用二分法查找列表中 f(x) 变化的位置(在 Python 中),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42119721/
我正在尝试编写一个程序来确定给定函数 (f(x) := ln((sin(x**(1/2))**3) + 2) - 1 的零点,使用二分法。值 a 和 b,它们是二分法中使用的初始值,已经插入到程序中。
二分法是搜索算法中极其典型的方法,其要求输入序列有序并可随机访问。算法思想为 。 输入:有序数组nums,目的数值target 要求输出:如果target存在在数组中,则输出其index,否则输出-
一旦找到正确的根(r3 的值 == 0),退出 while 循环就会遇到问题。我应该在某个地方休息吗?如果是的话——在哪里? 我已经尝试过使用 if、else if 和 else 语句的条件。尝试放置
我在做 this problem来自 lightoj 法官(抱歉提供链接,我不知道如何添加图片)。这是纯基于几何的问题,我的方法是这个导致接受的解决方案。 代码 #include using
是否有一个库函数对列表/元组执行二进制搜索,如果找到则返回项目的位置,如果没有则返回“False”(-1、None 等)? 我在 bisect module 中找到了函数 bisect_left/ri
我正在为二分法编写代码。 我的代码在下面,不知何故循环似乎没有开始。 没有特殊的编译问题。 我认为变量声明/函数原型(prototype)没有任何问题。 谁能帮我找到真正的问题所在? 最佳答案 标准b
用二分查找很容易找到一个整数even if it can be arbitrarily large :先猜数量级,再继续划分区间。 This answer描述了如何找到任意有理数。 设置场景后,我的问
昨天我在另一个 boost 功能上遇到了问题,但幸运的是你们帮助我解决了这些问题。今天我需要知道如何正确使用二分函数。 所以这就是我认为它应该如何工作,但似乎我也弄错了。好的,我想使用: templa
本文实例总结了PHP字符串逆序排列实现方法。分享给大家供大家参考,具体如下: 关于字符串的逆序排列,最简单的使用PHP函数strrev()的测试代码如下: ?
如下所示: ? 1
一. lamda匿名函数 为了解决一些简单的需求而设计的一句话函数 ?
我是一名优秀的程序员,十分优秀!