趣学Python算法100例】冒泡排序

问题描述

对N个整数(数据由键盘输入)进行升序排列。

问题分析

要整理一组相同类型的数,我们可以用一个叫数组的工具来存放它们。冒泡排序,就是通过一次次比较相邻的两个数并交换位置,让原本乱糟糟的数组变得井井有条。

具体怎么操作呢?首先,从数组的第一个数开始,一个接一个地往后看,每看到两个相邻的数,就比比谁大谁小。如果前面的数比后面的数大,我们就把它们俩换个位置,就像把不听话的小朋友往后挪一样,这样就消除了一处混乱。一边往后走,我们一边持续做这个"大数往后靠"的动作,最终,最大的数就会被推到数组的最后边,正合适。接着,我们忽略掉刚刚找到的最大数,对剩下的数重复刚才的步骤,再把第二大的数放到倒数第二个位置。就这么一遍遍重复,直到整个数组都排好队,最小的数在前,最大的数在后。

假如数组里总共有n个数,在最糟糕的情况下,我们需要做的比较次数会像这样增加:(n-1)加上(n-2),一直加到1。数学上一算,总共得比较n(n-1)/2次。

算法设计

冒泡排序嘛,想象一下这样的画面,就像吹泡泡,大的泡泡会慢慢浮到上面,小的沉下去,过程挺直观的,画个图就更一目了然了,就像下图那样。从头到尾看这个排序过程,你会发现一个规律,就是如果有一堆数字(比如说n个)要排序,你只需要比较n-1回就够了。拿7个数字来打个比方,要把它们排好队,其实只要比较6轮就能搞定,每次比较完,最大的数就会像泡泡一样浮到最后。图里那些加粗的数字,就是每轮比较后位置固定、不会再动的数了。

完整的程序

程序流程图如下图所示:

根据上面的分析,编写程序如下:

python 复制代码
def bubbleSort(a):
    """
    使用冒泡排序算法对列表a进行升序排序。
    
    参数:
    a (list): 待排序的整数列表。
    
    返回:
    list: 排序后的列表。
    """
    # 首先获取列表的总长度,为之后循环比较做准备
    n = len(a)
    
    # 检查输入是否为列表
    if not isinstance(a, list):
        raise ValueError("输入必须是一个列表")
    
    # 检查列表中的元素是否都是可比较的类型
    if not all(isinstance(x, (int, float)) for x in a):
        raise ValueError("列表中的所有元素必须是整数或浮点数")
    
    # 进行 n-1 次比较,控制比较的轮数
    i = 1
    while i <= n-1:
        # 控制每轮比较的次数
        j = 0
        while j < n-i:
            # 交换
            if a[j] > a[j+1]:
                t = a[j]
                a[j] = a[j+1]
                a[j+1] = t
            j += 1
        i += 1
    
    # 返回排序后的列表
    return a


if __name__=="__main__":
    print("请为列表元素赋初值,列表末尾不能有空格:")
    x = input()
    a = x.split(" ")                        # 以空格方式分割每个元素
    for i in range(0, len(a)):              # 输入多个值
        a[i] = int(a[i])
    print("你输入的列表元素为:\n", a)
    print("经过交换后的数组元素为:\n",bubbleSort(a))
    

运行结果

在VSCode里面启动你的程序时,它会友好地提醒你:"记得给数组的每个小格子填上初始值哦,还有,结尾处不要留下空格哟。"接下来,你只要输入两组不一样的初始数值,程序就会欢快地跑起来,最后展示给你的结果就像下图那样清晰明了。

相关推荐
花酒锄作田2 小时前
[python]argparse 包在聊天机器人中的应用
python
NiceCloud喜云4 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
小羊在睡觉5 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
3DVisionary5 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
AI玫瑰助手5 小时前
Python函数:默认参数的定义与注意事项
开发语言·python·信息可视化
好评笔记5 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466855 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
小糖学代码5 小时前
LLM系列:环境搭建:5.Python-dotenv 环境变量管理
人工智能·python·深度学习·神经网络
_日拱一卒5 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM6 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法