关于泡沫排序的家庭作业有效

时间:2017-02-17 01:58:01

标签: python sorting bubble-sort

我试图以有效的方式进行冒泡排序。我有一个计数,它累计了我对函数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]

我认为编辑我的冒泡代码可以解决这个问题,但即使我使用普通的冒泡排序功能,它也无法改变任何内容。

感谢任何帮助。谢谢。

2 个答案:

答案 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