繁体   English   中英

Python3 在列表中查找严格递增的“浮点值”组

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM