算法——python实现冒泡排序
2018-06-18 01:46:41来源:未知 阅读 ()
什么是冒泡排序?
- 首先,比较第一个数和第二个数的大小,由于是从小到大排列,所以如果第一个数大于第二个数,则将这两个数互换位置,反之则不变。
- 然后进行第二个数和第三个数比较,同上。
- 这样依次比较一轮后,你会发现,总共比了4次,也就是说,如果有n个数进行比较,那么需要n-1次才能完成。
- 上面过程主要完成了一轮比较,最终确定了一个最大的数,并且排在5个数的最后,也就是第五个数。
- 那么也就意味着需要在进行第一个数到第四个数的一轮比较,确定最大值。
- 接着从第一个数到第三个数......
- 这样规律就很明显了,五个数需要比较四轮,就能将5个数升序排列,所以n个数需要比较n-1轮。
如何实现?
到底该怎么实现呢?看了上面的分析,我相信你也能编出来吧!
看下我用python编的吧:
方法一:常规实现冒泡排序
# 方法1 # 定义一个列表,用于存放数字 list = [] while True: # 自定义输入数字个数 print('你想排列几个数?') try: num = int(input()) for i in range(num): a = int(input('请输入第' + str((i+1)) + '个整数:')) list.append(a) except ValueError: print('输入有误!') # 冒泡排序核心代码, for j in range(len(list)-1): for k in range(len(list)-1): if list[k] < list[k+1]: t = list[k] list[k] = list[k+1] list[k+1] = t print(list)
算法的优劣主要看它的时间复杂度,冒泡排序的时间复杂度为:O(N^2)
可以看出,冒泡排序的时间复杂度偏高,所以它还不是最优算法!
方法二:利用sorted()方法快速实现排序
# 定义一个列表对象存数字 list = [] print('你想排列几个数?') try: num = int(input()) for i in range(num): a = int(input('请输入第' + str((i + 1)) + '个整数:')) list.append(a) except ValueError: print('输入有误!') # 利用sorted()方法排序,并使用reverse字段实现降序 print(sorted(list, reverse=True))
非常推荐这种利用sorted()方法实现排序的方法,因为简单嘛!python就是以简洁为名,越少的代码实现相同的功能,何乐而不为!
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- python3基础之“术语表(2)” 2019-08-13
- python3 之 字符串编码小结(Unicode、utf-8、gbk、gb2312等 2019-08-13
- Python3安装impala 2019-08-13
- 小白如何入门 Python 爬虫? 2019-08-13
- python_字符串方法 2019-08-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash