我会使用itertools
,但是,如果您认为这很复杂(正如您在评论中暗示的那样),那么也许:
def twobytwo(t):
it = iter(t)
for x in it:
yield x, next(it)
d = dict(twobytwo(t))
或等效地,然后再次返回 itertools,
def twobytwo(t):
a, b = itertools.tee(iter(t))
next(b)
return itertools.izip(a, b)
d = dict(twobytwo(t))
或者,如果您坚持要内联,则以适合季节的“不给糖就捣蛋”的心情:
d = dict((x, next(it)) for it in (iter(t),) for x in it)
我,我认为这是一种技巧,但有些人可能会觉得这是一种享受。IOW,我觉得这种事情很可怕,但显然在美国每年的这个时候事情应该是;-)。
基本上,问题归结为“我如何一次遍历一个列表 2 个项目”,因为dict
很高兴将一个 2 元组序列放入字典中。我在这里展示的所有解决方案都确保只O(1)
占用额外的空间(O(N)
当然,除了空间之外,输入列表和输出字典需要这些空间)。
文档中建议的方法(每个人都应该熟悉该页面,itertool recipes)是pairwise
该页面上的功能,这基本上是我在这里建议的第二个。我确实认为每个站点包目录都应该包含一个包含iterutils.py
这些配方的文件(可惜这样的文件还不是 python 标准库的一部分!-)。