![](/img/trans.png)
[英]How to efficiently find the ordinal number of an element in a strictly increasing python list?
[英]Python3 find groups of strictly increasing “ float values” within a list
我找不到在列表中找到严格增加的“浮点值”组的解决方案。 我在网上找到的所有示例都是按“整数”类型值分组的。 我正在寻找的一个简单示例是获取浮点值序列的代码......为了清楚起见,请参阅下面的列表:
l = [8, 9, 10, -1.2, -1.1,-1.0, -10, -11, -12, 7, 8, 1.2, 2.3, 3.4]
下面的代码仅返回 integer 数字并忽略浮点数。 如果我使用“圆形” function 将列表更改为整数,它将破坏整个努力的目的......
我想要实现的是从上面的列表中严格增加“浮点值”的 output 返回 output 值: [[8, 9, 10],[-1.2,-1.1,-1.0], [7, 8 ], [1.2, 2.3, 3.4]]
最好地解释问题的代码:
def groupSequence(x):
it = iter(x)
prev, res = next(it), []
while prev is not None:
start = next(it, None)
if prev + 1 == start:
res.append(prev)
elif res:
yield list(res + [prev])
res = []
prev = start
l = [8, 9, 10, -1.2, -1.1 ,-1.0, -10, -11, -12, 7, 8, 1.2, 2.3, 3.4]
print(list(groupSequence(l)))
#当前 output: [[8, 9, 10], [7, 8]]
#desired output [[8, 9, 10],[-1.2,-1.1,-1.0], [7, 8], [1.2, 2.3, 3.4]]
任何帮助将非常感激。
问题出在这一行:
if prev + 1 == start:
序列中的浮点数不会增加一: -1.2 + 1 <> -1.1
if start and start > prev:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.