python冒泡排序代码通俗理解(详解python算法之冒泡排序)
python冒泡排序代码通俗理解
详解python算法之冒泡排序python之冒泡排序
概念: 重复地走访过要排序的元素列,依次比较两个相邻的元素,如果他们的顺序(如从大到小、首字母从a到z)错误就把他们交换过来。走访元素的工作是重复地进行直到没有相邻元素需要交换,也就是说该元素已经排序完成
这个算法的名字由来是因为越大的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。
算法原理
冒泡排序算法的原理如下:
比较相邻的元素。如果第一个比第二个大,就交换他们两个。
对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
针对所有的元素重复以上的步骤,除了最后一个。
持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
算法分析
时间复杂度
若文件的初始状态是正序的,一趟扫描即可完成排序。所需的关键字比较次数
和记录移动次数 均达到最小值: , 。
所以,冒泡排序最好的时间复杂度为 。
冒泡排序的最坏时间复杂度为
代码实现
伪代码
|
function bubble_sort (array, length) { var i, j; for (i from 1 to length - 1 ){ for (j from 0 to length - 1 - i){ if (array[j] > array[j + 1 ]) swap(array[j], array[j + 1 ]) } } } |
伪代码解释
函数 冒泡排序 输入 一个数组名称为array 其长度为length
i 从 1 到 (length - 1)
j 从 0 到 (length - 1 - i)
如果 array[j] > array[j + 1]
交换 array[j] 和 array[j + 1] 的值
如果结束
j循环结束
i循环结束
函数结束
助记码
|
i∈[ 0 ,n - 1 ) / / 循环n - 1 遍 j∈[ 0 ,n - 1 - i) / / 每遍循环要处理的无序部分 swap(j,j + 1 ) / / 两两排序(升序 / 降序) |
python代码
|
#-*-coding:utf-8-*- '''冒泡排序也称 bubble sort从小到大排序''' import time def bubble_sort(lst): '''冒泡排序''' # 第一次循环 for n in range ( len (lst) - 1 , 0 , - 1 ): #计算原列表的长度-1,取倒序索引 for i in range (n): if lst[i] > lst[i + 1 ]: # 比较最后一个与倒数第二个数的值,如果倒数第二个的值,大于最后一个的值 temp = lst[i] # 则将倒数第二个值赋值给临时变量temp lst[i] = lst[i + 1 ] # 替换原列表中倒数第二个索引的值为最后一个 lst[i + 1 ] = temp # 同时改变原列表中最后一个索引值为倒数第二个的值 return lst if __name__ = = "__main__" : lst = [ 54 , 26 , 93 , 17 , 77 , 31 , 44 , 55 , 20 ] af_sort = bubble_sort(lst) print (af_sort) |
总结冒泡排序的实现(类似下面)通常会对已经排序好的数列拙劣地运行(),而插入排序在这个例子只需要个运算。算法的核心知识点是: 循环比较, 交叉换位!
原文链接:https://www.cnblogs.com/failymao/p/10474674.html
- python中list怎么用(详解python中list的使用)
- python自带的ide的使用(基于python的ini配置文件操作工具类)
- python解析视频源码(基于python实现高速视频传输程序)
- python class转json(Python对象转换为json的方法步骤)
- python 绕过密码(一小段Python代码,破解加密zip文件的密码)
- 如何用python画函数图(使用python绘制二元函数图像的实例)
- python 串口图形化(python使用MQTT给硬件传输图片的实现方法)
- python3语法规则(详解Python3注释知识点)
- pythonsocket教程(python3利用Socket实现通信的方法示例)
- python列表反转的方法(Python实现的列表排序、反转操作示例)
- 如何去阿里云解析域名(利用Python+阿里云实现DDNS动态域名解析的方法)
- python樱花绽放代码(新年快乐! python实现绚烂的烟花绽放效果)
- python scrapy爬虫教程视频(详解python3 + Scrapy爬虫学习之创建项目)
- python符串操作教程(Python3.5运算符操作实例详解)
- python端口扫描脚本测试(Python实现的IP端口扫描工具类示例)
- python3标准库资源(Python3标准库总结)
- 法国面包(法国面包法棍)
- 微信(微信分身)
- 双十二(双十二和双十一哪个划算)
- 佛肚竹盆景的养护之道(佛肚竹盆景的养护之道)
- 包水饺(包水饺手法怎么包视频)
- 越南河粉(越南河粉来自哪里)
热门推荐
- mysql 查询语句group by用法(MySQL group by和order by如何一起使用)
- docker部署kafka认证(docker-compose部署zk+kafka+storm集群的实现)
- sql版本号处理并发(SQL server高并发生成唯一订单号的方法实现)
- js中数组的操作
- php array只能放一种类型的数据(浅谈PHP array_search 和 in_array 函数效率问题)
- dedecms无缩略图怎么设置(DEDECMS系统分页标签自定义二次开发实例)
- mysql有什么索引(MySQL 普通索引和唯一索引的区别详解)
- web前端开发怎么算乘法(如何计算Web动画帧率FPS)
- 让VS中Release模式下不生成pdb文件
- 火狐和IE的window.event的区别
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9