网站首页 > 基础教程 正文
众所周知冒泡排序是最简单的排序算法,其核心原理是对于随机给定的一个列表中的n个元素, 可以通过比较和交换相邻的元素来实现元素的排序。具体规则如下:
第1轮排序, 从左至右比较相邻元素的大小n-1次, 若相邻元素a大于b, 则交换a和b的位置, 结束后给定的n个元素中最大的元素是列表最后一个元素。
第2轮排序, 从左至右比较相邻元素的大小n-2次, 若相邻元素a大于b, 则交换a和b的位置, 结束后给定的n个元素中第2大的元素是列表倒数第二个元素。
第3轮排序, 从左至右比较相邻元素的大小n-3次, 若相邻元素a大于b, 则交换a和b的位置, 结束后给定的n个元素中第3大的元素是列表倒数第三个元素。
......
第n-1轮排序,从左至右比较相邻元素的大小1次, 若相邻元素a大于b, 则交换a和b的位置, 结束后给定的n个元素中第二小的元素是列表第二个元素。排序结束。
以下为实现的代码:
# coding: utf-8
def my_bubble(my_list):
n = len(my_list)
for i in range(n - 1):
for j in range(n - 1 - i):
if my_list[j] > my_list[j + 1]:
my_list[j], my_list[j + 1] = my_list[j + 1], my_list[j]
if __name__ == '__main__':
elements_list = [5, 1, 9, 2, 0, 1, 3, 7, 4, 6, 8, 1]
print("排序前:")
print(elements_list)
my_bubble(elements_list)
print("排序后:")
print(elements_list)
不足之处请批评指正,欢迎讨论~~~
- 上一篇: 十大排序算法介绍及python实现
- 下一篇: Python函数知识整理
猜你喜欢
- 2024-11-22 Python 实现经典算法之堆排序
- 2024-11-22 Python版排序算法总结
- 2024-11-22 python冷门操作-11.list排序干货
- 2024-11-22 Python 排序了解一下
- 2024-11-22 Python实现冒泡排序
- 2024-11-22 Python 快速排序:高效算法一探究竟
- 2024-11-22 Python实现快速排序
- 2024-11-22 python对象自定义排序你知道吗
- 2024-11-22 Python应用——自定义排序全套方案
- 2024-11-22 Python函数知识整理
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)