python如何进行冒泡排序

冷漠man
发布: 2025-12-05 22:32:35
原创
346人浏览过
冒泡排序是通过重复遍历列表、比较相邻元素并交换使较大(或较小)元素逐步“冒泡”至一端的排序算法;Python实现中,外层控制轮数,内层两两比较交换,可用flag优化提前终止。

python如何进行冒泡排序

冒泡排序是一种基础的排序算法,原理简单:重复遍历列表,比较相邻元素,把较大的(或较小的)逐个“冒泡”到一端。Python 实现起来很直观,适合理解排序逻辑。

基本实现(升序)

核心思路:每轮遍历把当前未排序部分的最大值移到末尾。

说明:外层循环控制轮数(最多 n-1 轮),内层循环负责两两比较和交换;每轮结束后,末尾元素就已就位,所以下一轮范围可缩小。

建议写法:

立即学习Python免费学习笔记(深入)”;

HiDream AI
HiDream AI

全中文AIGC创作平台和AI社区

HiDream AI 266
查看详情 HiDream AI
  • len(arr) - 1 - i 控制内层边界,避免重复比较已排好的末尾元素
  • 加入 flag 优化:若某轮没发生交换,说明已有序,可提前退出

示例代码:

def bubble_sort(arr):
    n = len(arr)
    for i in range(n):
        swapped = False  # 标记本轮是否发生交换
        for j in range(0, n - 1 - i):
            if arr[j] > arr[j + 1]:
                arr[j], arr[j + 1] = arr[j + 1], arr[j]
                swapped = True
        if not swapped:
            break
    return arr
<h1>测试</h1><p>nums = [64, 34, 25, 12, 22, 11, 90]
print(bubble_sort(nums))  # [11, 12, 22, 25, 34, 64, 90]
登录后复制

降序排列只需改一个符号

把内层判断条件 arr[j] > arr[j + 1] 改成 arr[j] 即可,其余逻辑完全不变。

注意:原地排序 vs 返回新列表

上面的实现是原地修改输入列表。如果想保留原列表不变,可以先复制一份:

  • arr.copy()arr[:] 创建副本再排序
  • 不推荐直接返回 sorted(arr)——那用的是Timsort,不是冒泡

基本上就这些。冒泡排序时间复杂度是 O(n²),不适合大数据量,但写起来快、逻辑清晰,是入门必练算法之一。

以上就是python如何进行冒泡排序的详细内容,更多请关注php中文网其它相关文章!

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号