我用一个代码通过多个索引以相反的顺序迭代一个字符串或列表,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都到达弦的末端? 感谢
答案 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