python算法:最易学图解:排序:冒泡排序
off999 2024-10-27 11:50 26 浏览 0 评论
一,什么是冒泡排序?
1,冒泡排序和快速排序都属于交换排序
所谓交换,就是对序列中两个元素根据键值的比较结果来对换这两个记录在序列中的位置
交换排序的特点:将键值较大的元素向序列的尾部移动,键值较小的元素向序列的前部移动
2,冒泡排序:Bubble Sort,是一种最基础的交换排序,
冒泡排序:从序列的一端开始往另一端冒泡,依次比较相邻的两个数的大小,
按需要对数据进行交换,达到最终的排序效果
3,排序过程:以升序排序为例:
设数组长度为n
a, 每轮比较相邻的前后两个数据,如果前面数据大于后面的数据,就将二个数据交换。
b, 每轮都对未排序部分进行遍历,
最大的数据会被交换到未排序部分的最后,
下一轮循环时,对比较的数字范围-1,
不再比较已交换到最后的最大数字
c, 每轮把比较范围内最大的一个数字放到最后,
比较n-1轮后排序完成
二,示意图:
1,冒泡排序的过程
第一轮遍历前的数据:
比较3和5,无需交换
比较5和9,无需交换
比较9和7,需要交换
比较9和2,需要交换
比较9和1,需要交换
第二轮遍历后的结果:(注意此轮不再比较最后的9,只比较前5个数字即可)
第三轮遍历后的结果:(注意此轮不再比较最后的7、9,只比较前4个数字即可)
第四轮遍历后的结果:(注意此轮不再比较最后的5、7、9,只比较前3个数字即可)
第五轮遍历后的结果:(注意此轮不再比较最后的3、5、7、9,只比较前2个数字即可)
最终结果:
2, 总结:
设数据长度为n
a,需要进行多少轮冒泡?
n-1轮,-1是因为剩下最后一个数字之后无需再排序
b,每轮要比较多少个数字?
设当前为第i轮(从0开始),需要比较n-i个数字
c, 每轮要比较多少次?
因为每次比较两个,到最后一个数字时无需再比较,所以需要比较n-i-1次
三,动图演示:
四,python代码:
代码:
# data:要排序的数据
def bubble(data):
n = len(data) # 得到数据长度n
# 排序,对数据遍历n-1轮,因为最后剩下一个元素时,无需再排
for i in range(n - 1):
end = n - i - 1 # 每轮需比较n-i个数据,共需比较n-i-1次
for j in range(0, end): # 开始比较相邻的两个数据
if (data[j] > data[j + 1]): # 前一个元素>后一个元素时,交换
data[j], data[j + 1] = data[j + 1], data[j]
print(f"第{i + 1}轮排序后:", data)
data = [3, 5, 9, 7, 2, 1]
print("排序开始前:", data)
bubble(data)
print("排序完成后:", data)
运行结果:
排序开始前: [3, 5, 9, 7, 2, 1]
第1轮排序后: [3, 5, 7, 2, 1, 9]
第2轮排序后: [3, 5, 2, 1, 7, 9]
第3轮排序后: [3, 2, 1, 5, 7, 9]
第4轮排序后: [2, 1, 3, 5, 7, 9]
第5轮排序后: [1, 2, 3, 5, 7, 9]
排序完成后: [1, 2, 3, 5, 7, 9]
五,总结
冒泡排序:有两个嵌套的循环,用时间较长
平均时间复杂度: O(n2)
最差情形复杂度: O(n2)
空间复杂度: O(1)
相关推荐
- pip的使用及配置_pip怎么配置
-
要使用python必须要学会使用pip,pip的全称:packageinstallerforpython,也就是Python包管理工具,主要是对python的第三方库进行安装、更新、卸载等操作,...
- Anaconda下安装pytorch_anaconda下安装tensorflow
-
之前的文章介绍了tensorflow-gpu的安装方法,也介绍了许多基本的工具与使用方法,具体可以看Ubuntu快速安装tensorflow2.4的gpu版本。pytorch也是一个十分流行的机器学...
- Centos 7 64位安装 python3的教程
-
wgethttps://www.python.org/ftp/python/3.10.13/Python-3.10.13.tgz#下载指定版本软件安装包tar-xzfPython-3.10.1...
- 如何安装 pip 管理工具_pip安装详细步骤
-
如何安装pip管理工具方法一:yum方式安装Centos安装python3和python3-devel开发包>#yuminstallgcclibffi-develpy...
- Python入门——从开发环境搭建到hello world
-
一、Python解释器安装1、在windows下步骤1、下载安装包https://www.python.org/downloads/打开后选择【Downloads】->【Windows】小编是一...
- 生产环境中使用的十大 Python 设计模式
-
在软件开发的浩瀚世界中,设计模式如同指引方向的灯塔,为我们构建稳定、高效且易于维护的系统提供了经过验证的解决方案。对于Python开发者而言,理解和掌握这些模式,更是提升代码质量、加速开发进程的关...
- 如何创建和管理Python虚拟环境_python怎么创建虚拟环境
-
在Python开发中,虚拟环境是隔离项目依赖的关键工具。下面介绍创建和管理Python虚拟环境的主流方法。一、内置工具:venv(Python3.3+推荐)venv是Python标准...
- 初学者入门Python的第一步——环境搭建
-
Python如今成为零基础编程爱好者的首选学习语言,这和Python语言自身的强大功能和简单易学是分不开的。今天千锋武汉Python培训小编将带领Python零基础的初学者完成入门的第一步——环境搭建...
- 全网最简我的世界Minecraft搭建Python编程环境
-
这篇文章将给大家介绍一种在我的世界minecraft里搭建Python编程开发环境的操作方法。目前看起来应该是全网最简单的方法。搭建完成后,马上就可以利用python代码在我的世界自动创建很多有意思的...
- Python开发中的虚拟环境管理_python3虚拟环境
-
Python开发中,虚拟环境管理帮助隔离项目依赖,避免不同项目之间的依赖冲突。虚拟环境的作用隔离依赖:不同项目可能需要不同版本的库,虚拟环境可以为每个项目创建独立的环境。避免全局污染:全局安装的库可...
- Python内置zipfile模块:操作 ZIP 归档文件详解
-
一、知识导图二、知识讲解(一)zipfile模块概述zipfile模块是Python内置的用于操作ZIP归档文件的模块。它提供了创建、读取、写入、添加及列出ZIP文件的功能。(二)ZipFile类1....
- Python内置模块pydoc :文档生成器和在线帮助系统详解
-
一、引言在Python开发中,良好的文档是提高代码可读性和可维护性的关键。pydoc是Python自带的一个强大的文档生成器和在线帮助系统,它可以根据Python模块自动生成文档,并支持多种输出格式...
- Python sys模块使用教程_python system模块
-
1.知识导图2.sys模块概述2.1模块定义与作用sys模块是Python标准库中的一个内置模块,提供了与Python解释器及其环境交互的接口。它包含了许多与系统相关的变量和函数,可以用来控制P...
- Python Logging 模块完全解读_python logging详解
-
私信我,回复:学习,获取免费学习资源包。Python中的logging模块可以让你跟踪代码运行时的事件,当程序崩溃时可以查看日志并且发现是什么引发了错误。Log信息有内置的层级——调试(deb...
- 软件测试|Python logging模块怎么使用,你会了吗?
-
Pythonlogging模块使用在开发和维护Python应用程序时,日志记录是一项非常重要的任务。Python提供了内置的logging模块,它可以帮助我们方便地记录应用程序的运行时信息、错误和调...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)