在课堂上,我们正在做排序算法,尽管我在谈论它们和编写伪代码时很好地理解了它们,但我在为它们编写实际代码时遇到了问题。
这是我在Python中的尝试:
mylist = [12, 5, 13, 8, 9, 65]
def bubble(badList):
length = len(badList) - 1
unsorted = True
while unsorted:
for element in range(0,length):
unsorted = False
if badList[element] > badList[element + 1]:
hold = badList[element + 1]
badList[element + 1] = badList[element]
badList[element] = hold
print badList
else:
unsorted = True
print bubble(mylist)
现在,这个(据我所知)是正确排序的,但是一旦它完成,它就会无限循环。
如何修复此代码,以便函数正确结束并正确地对任意(合理)大小的列表进行排序?
附注:我知道我不应该真的在一个函数中有打印,我应该有一个返回,但我还没有这样做,因为我的代码还不能真正工作。
https://stackoverflow.com/questions/895371
复制相似问题