我正在使用以下(丑陋的)代码片段迭代带有字符串的二维列表。它检查其中一个值是否为'0'
,以及它是否不是最后一个元素。如果不是,它将使用下一个元素的值切换当前元素(即'0'
)的值。
我打算用此功能完成的任务是将所有非'0'
值都推回后面。显然,它还没有按预期的方式工作(这是一个开始),但是我想不出一种方法来解决这个问题,而又不会把它弄得一团糟。
拼图中缺少的是什么?递归在这里有帮助吗?
['0', '2', '0', '4']
应该变成
['2', '4', '0', '0']
和
['0', '3', '1', '0', '2']
进入
['3', '1', '2', '0', '0']
当前代码段:
for idx, x in enumerate(self.list_x):
for idy, i in enumerate(x):
if i == '0':
try:
if x[idy+1]:
pass
except IndexError:
pass
else:
temp = i
self.list_x[idx][idy] = x[idy+1]
self.list_x[idx][idy+1] = temp
最佳答案
In [63]: A = ['0', '2', '0', '4']
In [64]: B = ['0', '3', '1', '0', '2']
In [65]: [i for i in A if i!='0'] + [i for i in A if i=='0']
Out[65]: ['2', '4', '0', '0']
In [66]: [i for i in B if i!='0'] + [i for i in B if i=='0']
Out[66]: ['3', '1', '2', '0', '0']
关于python-2.7 - 将所有非-'0'推到前面,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/33160232/