如何解决Python:获取连续至少 3 个元素的索引?
(这不是家庭作业,我在自学)
我有一本字典(实际上是一个 Counter
),其中包含一些计数数字(称为 n
)以及该数字出现的次数(称为 c
)。即
my_dict = { n0: c0,n1: c1,...,nx: cx }
如果 c
是连续的,我想将其转换为 n
的子列表。即如果
my_dict = { 0: 1,1: 1,4: 1,5: 2,6: 1 }
我愿意
result = [ [ 1,1 ],[ 1,2,1 ] ]
我可以在索引上使用 for 循环,但这不是 Pythonic。但是,此时我正在使用多个 itertools
函数,但仍然没有得到我想要的。
我能得到建议吗?
解决方法
for
循环可能是最简单的解决方案;迭代字典的键,当键不等于最后一个键加 1 时,在输出中开始一个新列表,否则附加到当前列表:
my_dict = { 0: 1,1: 1,4: 1,5: 2,6: 1 }
l = []
last = max(my_dict.keys())
for k,v in my_dict.items():
if k != last + 1:
l.append([v])
else:
l[-1].append(v)
last = k
print(l)
输出:
[[1,1],[1,2,1]]
,
函数式编程有时很可怕:
onSuccess: function(success) {
var myPlayer = success.ref;
myPlayer.on('ended',function(){
console.log('video ended...');
});
},
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。