【发布时间】:2020-08-14 16:58:28
【问题描述】:
问题
问题链接: https://www.codewars.com/kata/52597aa56021e91c93000cb0/train/python
编写一个算法,该算法采用一个数组并将所有零移到末尾,同时保留其他元素的顺序。
move_zeros([false,1,0,1,2,0,1,3,"a"]) # returns[false,1,1,2,1,3,"a",0,0]
我的代码:
def move_zeros(array):
zero_count = array.count(0)
array1 = list(filter(lambda a: a != 0, array)) + [0 for i in range(zero_count)]
return array1
样本测试:
Test.describe("Basic tests")
Test.assert_equals(move_zeros([1,2,0,1,0,1,0,3,0,1]),[ 1, 2, 1, 1, 3, 1, 0, 0, 0, 0 ])
Test.assert_equals(move_zeros([9,0.0,0,9,1,2,0,1,0,1,0.0,3,0,1,9,0,0,0,0,9]),[9,9,1,2,1,1,3,1,9,9,0,0,0,0,0,0,0,0,0,0])
Test.assert_equals(move_zeros(["a",0,0,"b","c","d",0,1,0,1,0,3,0,1,9,0,0,0,0,9]),["a","b","c","d",1,1,3,1,9,9,0,0,0,0,0,0,0,0,0,0])
Test.assert_equals(move_zeros(["a",0,0,"b",None,"c","d",0,1,False,0,1,0,3,[],0,1,9,0,0,{},0,0,9]),["a","b",None,"c","d",1,False,1,3,[],1,9,{},9,0,0,0,0,0,0,0,0,0,0])
Test.assert_equals(move_zeros([0,1,None,2,False,1,0]),[1,None,2,False,1,0,0])
Test.assert_equals(move_zeros(["a","b"]),["a","b"])
Test.assert_equals(move_zeros(["a"]),["a"])
Test.assert_equals(move_zeros([0,0]),[0,0])
Test.assert_equals(move_zeros([0]),[0])
Test.assert_equals(move_zeros([False]),[False])
Test.assert_equals(move_zeros([]),[])
我运行后的输出:
测试通过
测试通过
测试通过
['a', 'b', 无, 'c', 'd', 1, 1, 3, [], 1, 9, {}, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] 应该等于 ['a', 'b', None, 'c', 'd', 1, False, 1, 3, [], 1, 9, {}, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
-
[1, None, 2, 1, 0, 0, 0] 应该等于 [1, None, 2, False, 1, 0, 0]
测试通过
测试通过
测试通过
测试通过
测试通过
测试通过
我的问题:
为什么我的答案未能通过 2 次测试?
【问题讨论】:
-
只需在循环中交换,并跟踪最后一个非零位置。
-
@EricWang 非常感谢您的想法:) 请提供代码解决方案。
标签: python arrays algorithm sorting optimization