我有一个整数列表,我想识别连续的重复块:也就是说,我想生成一个保持顺序的元组列表,每个元组包含(待检查的整数,出现次数)。
例如,如果我有一个列表如下:
例如,如果我有一个列表如下:
[0, 0, 0, 3, 3, 2, 5, 2, 6, 6]
我希望得到的结果是:
[(0, 3), (3, 2), (2, 1), (5, 1), (2, 1), (6, 2)]
我有一个相对简单的方法,使用for循环、一个临时变量和一个计数器:
result_list = []
current = source_list[0]
count = 0
for value in source_list:
if value == current:
count += 1
else:
result_list.append((current, count))
current = value
count = 1
result_list.append((current, count))
但我非常喜欢Python的函数式编程习惯,并且我希望能够使用简单的生成器表达式来实现。然而,当使用生成器时很难保留子计数。我有一种感觉,两步法可以帮我做到这一点,但现在我卡住了。
有没有特别优雅/Pythonic的方法来实现这一点,特别是使用生成器?