通过4个索引进行同步迭代

时间:2018-02-06 14:35:14

标签: python python-3.x loops for-loop iteration

我用一个代码通过多个索引以相反的顺序迭代一个字符串或列表,2个前进,2个后退。 但是由于在迭代1和迭代3中给出for循环的范围限制,我无法获得最终的char或list元素。 这是代码:

mix = 'fdsfef232'
for i in range(len(mix)-1):
    print('Iter 1:>>>',mix[i],'\tIter 2:>>>',mix[i+1],'\tIter 3:>>>',mix[-1-i],'\tIter 4:>>>',mix[-2-i])

这是输出:

Iter 1:>>> f    Iter 2:>>> d    Iter 3:>>> 2    Iter 4:>>> 3
Iter 1:>>> d    Iter 2:>>> s    Iter 3:>>> 3    Iter 4:>>> 2
Iter 1:>>> s    Iter 2:>>> f    Iter 3:>>> 2    Iter 4:>>> f
Iter 1:>>> f    Iter 2:>>> e    Iter 3:>>> f    Iter 4:>>> e
Iter 1:>>> e    Iter 2:>>> f    Iter 3:>>> e    Iter 4:>>> f
Iter 1:>>> f    Iter 2:>>> 2    Iter 3:>>> f    Iter 4:>>> s
Iter 1:>>> 2    Iter 2:>>> 3    Iter 3:>>> s    Iter 4:>>> d
Iter 1:>>> 3    Iter 2:>>> 2    Iter 3:>>> d    Iter 4:>>> f

如何确保Iter 1和Iter 3都到达弦的末端? 感谢

2 个答案:

答案 0 :(得分:1)

from collections import deque

mix = deque('fdsfef232')
while len(mix)>=4:
    print('Iter 1:>>>', mix.popleft())
    print('Iter 2:>>>', mix.popleft())
    print('Iter 3:>>>', mix.pop())
    print('Iter 4:>>>', mix.pop())


if len(mix)>0:
    print('Iter 1:>>>', mix.popleft())

if len(mix)>0:
     print('Iter 2:>>>', mix.popleft())

if len(mix)>0:
    print('Iter 3:>>>', mix.popleft())

答案 1 :(得分:1)

已经给出了模块collections的有效答案,这里没有import

基本上计算索引,考虑到输入字符串长度的限制,以及达到结束时的回绕,例如:

mix = 'fdsfef232'
for i in range(len(mix)):
    a = i
    b = 0 if (i+1) > len(mix)-1 else i+1
    c = 0 if (-1-i) < (0-len(mix)-1) else -1-i
    d = -1 if (-2-i) < (0-len(mix)) else -2-i
    print('Iter 1:>>>',mix[a],'\tIter 2:>>>',mix[b],'\tIter 3:>>>',mix[c],'\tIter 4:>>>',mix[d])

输出:

Iter 1:>>> f    Iter 2:>>> d    Iter 3:>>> 2    Iter 4:>>> 3
Iter 1:>>> d    Iter 2:>>> s    Iter 3:>>> 3    Iter 4:>>> 2
Iter 1:>>> s    Iter 2:>>> f    Iter 3:>>> 2    Iter 4:>>> f
Iter 1:>>> f    Iter 2:>>> e    Iter 3:>>> f    Iter 4:>>> e
Iter 1:>>> e    Iter 2:>>> f    Iter 3:>>> e    Iter 4:>>> f
Iter 1:>>> f    Iter 2:>>> 2    Iter 3:>>> f    Iter 4:>>> s
Iter 1:>>> 2    Iter 2:>>> 3    Iter 3:>>> s    Iter 4:>>> d
Iter 1:>>> 3    Iter 2:>>> 2    Iter 3:>>> d    Iter 4:>>> f
Iter 1:>>> 2    Iter 2:>>> f    Iter 3:>>> f    Iter 4:>>> 2