我正在使用以下(丑陋的)代码片段迭代带有字符串的二维列表。它检查其中一个值是否为'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/

10-13 04:59