5

使用以下示例列表:L = ['a','b','c','d']

我想实现以下输出:

>>> a d b
>>> b a c
>>> c b d
>>> d c a

伪代码将是:

for e in L:
    print(e, letter_before_e, letter_after_e
4

5 回答 5

7

您可以循环L并取索引i减和加 1 模len(L)来获取上一个和下一个元素。

于 2012-08-17T17:59:06.953 回答
6

你几乎在那里

for i, e in enumerate(L):
    print(e, L[i-1], L[(i+1) % len(L)])

编辑添加模组

于 2012-08-17T18:02:35.087 回答
1

在这种情况下可能会有点矫枉过正,但这是循环双向链表的一般用例http://ada.rg16.asn-wien.ac.at/~python/how2think/english/chap17.htm

于 2012-08-17T18:00:54.567 回答
0

从概念上讲,跟踪您已经看到的项目通常比向前看更简单。该类deque非常适合跟踪n以前的项目,因为它允许您设置最大长度;添加新项目会自动将旧项目推开。

from collections import deque

l = ['a','b','c','d']
d = deque(l[-2:], maxlen=3)

for e in l:
    d.append(e)
    print d[1], d[0], d[2]

此解决方案的唯一区别是d c a它将先出现而不是最后出现。如果这很重要,您可以像已经看过一次迭代一样开始:

from collections import deque

l = ['a','b','c','d']
d = deque(l[-1:] + l[:1], maxlen=3)

for e in l[1:] + l[:1]:
    d.append(e)
    print d[1], d[0], d[2]
于 2012-08-17T18:34:01.363 回答
0

在我的代码中,我将在由最后一个元素添加并由第一个元素添加的列表上使用 3 个元素的移动窗口:

from itertools import tee, izip, chain

def window(iterable,n):
    '''Moving window
    window([1,2,3,4,5],3) -> (1,2,3), (2,3,4), (3,4,5)
    '''
    els = tee(iterable,n)
    for i,el in enumerate(els):
        for _ in range(i):
            next(el, None)
    return izip(*els)


def chunked(L):
    it = chain(L[-1:], L, L[:1]) # (1,2,3,4,5) -> (5,1,2,3,4,5,1)
    for a1,a2,a3 in window(it,3): # (3,1,2,3,1) -> (3,1,2), (1,2,3), (2,3,1)
        yield (a2,a1,a3)


## Usage example ##
L = ['a','b','c','d']

for t in chunked(L):
    print(' '.join(t))
于 2012-08-17T18:28:48.823 回答