我试图以有效的方式进行冒泡排序。我有一个计数,它累计了我对函数bubble
所做的所有调用。我需要找到一种方法来提高效率,如果调用bubble
函数并且列表中的值没有交换,那么我就不应该再次调用bubble函数。
这里有三个函数的代码
def bubble_sort(values):
count = 0
for i in range(len(values)-1):
count += 1
bubble(values)
return count
def bubble(values):
while True:
swapped = False
for i in range(len(values) - 1):
if values[i] > values[i + 1]:
swap(values, i, i+1)
swapped = True
if not swapped:
break
def swap(values, i, j):
values[i], values[j] = values[j], values[i]
test_1 = [1, 3, 67, 58, 91, 36, 100, 28, 90, 10, 57, 51, 52, 64, 56]
x = bubble_sort(test_1)
print(x, test_1)
test_2 = [2, 3, 4, 1, 5, 6, 7]
y = bubble_sort(test_2)
print(y, test_2)
当我尝试运行以下代码时,我得到的输出是:
14 [1, 3, 10, 28, 36, 51, 52, 56, 57, 58, 64, 67, 90, 91, 100]
预期输出为:
8 [1, 3, 10, 28, 36, 51, 52, 56, 57, 58, 64, 67, 90, 91, 100]
我认为编辑我的冒泡代码可以解决这个问题,但即使我使用普通的冒泡排序功能,它也无法改变任何内容。
感谢任何帮助。谢谢。
答案 0 :(得分:1)
如果没有掉期,您需要在bubble_sort
中调出bubble
的外部循环。只需从while
移除bubble
并返回一个bool,指示是否进行了互换。然后,如果您将for
作为返回值,则可以停止bubble_sort
中的False
循环:
def bubble_sort(values):
count = 0
for i in range(len(values)-1):
count += 1
if not bubble(values):
break
return count
def bubble(values):
swapped = False
for i in range(len(values) - 1):
if values[i] > values[i + 1]:
swap(values, i, i+1)
swapped = True
return swapped
通过这些修改,您可以获得预期的输出:
(8, [1, 3, 10, 28, 36, 51, 52, 56, 57, 58, 64, 67, 90, 91, 100])
(4, [1, 2, 3, 4, 5, 6, 7])
答案 1 :(得分:1)
高效的冒泡排序。哈
一个简单的解决方法就是让bubble
函数返回False
,如果它不执行任何交换。
def bubble(values):
has_changed = False
while True:
swapped = False
for i in range(len(values) - 1):
if values[i] > values[i + 1]:
swap(values, i, i+1)
has_changed = True
swapped = True
if not swapped:
break
return has_changed
然后,在bubble_sort
函数中:
def bubble_sort(values):
count = 0
for i in range(len(values)-1):
count += 1
has_changed = bubble(values)
if has_changed == False:
break
return count