冒泡排序——Python实现

醉酒当歌 提交于 2019-12-02 16:37:21

冒泡排序Python实现

# -*- coding: utf-8 -*-
# @Time    : 2019/10/28 19:41
# @Author  : yuzhou_1shu
# @Email   : yuzhou_1shu@163.com
# @File    : bubble_sort.py
# @Software: PyCharm


def bubble_sort(collection):

    # 求序列的长度
    length = len(collection)
    # 从序列中第一个元素开始以此跟后一个比较
    for i in range(length - 1):
        swapped = False
        for j in range(length - i - 1):
            if collection[j] > collection[j+1]:
                collection[j], collection[j+1] = collection[j+1], collection[j]
                swapped = True
        if not swapped:
            break   # 如果已经排序好了,退出循环
    return collection


if __name__ == "__main__":
    import time

    user_input = input("请输入数字,并以英文逗号隔开: ").strip()
    unsorted = [int(item) for item in user_input.split(",")]
    start_time = time.process_time()
    print("排序后:", *bubble_sort(unsorted), sep=",")
    print(f"排序消耗时间: {time.process_time() - start_time}秒")

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!