python算法与数据结构之冒泡排序实例详解


Posted in Python onJune 22, 2019

一、冒泡排序介绍

冒泡排序(英语:Bubble Sort)是一种简单的排序算法。它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

二、冒泡排序原理

  1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
  2. 对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。这一步做完,最后的元素应该会是最大的数。
  3. 针对所有的元素重复以上的步骤,除了最后一个。
  4. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

三、冒泡排序图解

python算法与数据结构之冒泡排序实例详解

python算法与数据结构之冒泡排序实例详解

python算法与数据结构之冒泡排序实例详解

python算法与数据结构之冒泡排序实例详解

python算法与数据结构之冒泡排序实例详解

python算法与数据结构之冒泡排序实例详解

四、冒泡排序总结

有N个数据需要比较N-1趟

每趟比较N-i次,i表示第几趟,例如7个数据,第四趟需要比较 7-4 = 3次

五、冒泡排序python代码实现

def bubble_sort(numlist):
 # 需要排列的数据个数
 N = len(numlist)
 # i 控制一共需要多少趟 N-1
 for i in range(N-1):
  # j 控制每趟需要比较多少次(因为i是从0开始,所以N-i-1)
  for j in range(N-i-1):
   # 判断j和j+1两个位置的数据大小
   if numlist[j]>numlist[j+1]:
    # 交换(交换的代码有很多种写法)
    temp = numlist[j]
    numlist[j] = numlist[j+1]
    numlist[j+1] = temp
   
list = [19,2,13,8,34,25,7]
print("排序前list = %s"%list)
bubble_sort(list)
print("排序后list = %s"%list)

运行结果为:

排序前list = [19, 2, 13, 8, 34, 25, 7]
排序后list = [2, 7, 8, 13, 19, 25, 34]

六、冒泡排序C语言代码实现

#include <stdio.h>
// 创建一个冒泡函数,需要传递一个数组,和数组的长度
void bubble_sort(int array[],int arrayLength)
{
 // i 控制一共需要循环多少趟,
 for (int i=0; i<arrayLength-1; i++)
 {
  // j 控制每趟循环多少次
  for (int j=0; j<arrayLength-i-1; j++)
  {
   //判断j和j+1位置上数的大小
   if (array[j]>array[j+1])
   {
    //交换
    int temp = array[j];
    array[j] = array[j+1];
    array[j+1] = temp;
   }
  }
 }
}

int main(int argc, const char * argv[])
{
 // 函数的声明
 void bubble_sort(int array[],int arrayLength);
 // 创建一个数组
 int numArray[] = {19,2,13,8,34,25,7};
 //进行排序
 bubble_sort(numArray,7);
 
 printf("打印排序后的数组是:\n");
 for (int i=0; i<7; i++)
 {
  printf("%d ",numArray[i]);
 }
 return 0;
}

运算结果为:

打印排序后的数组是:

2 7 8 13 19 25 34

七、冒泡排序的优化

通过上面的案例我们已经知道冒泡排序的原理和实现过程,但是在处理一些特殊数据上的时候,我们还可以对冒泡排序优化,例如:一个数组本来就是有序,1,2,3,4,5,6,7,这样的一个数组已经是正确的顺序的,我们只需要比较一趟后,发现这一趟所有的数据都没有发生改变,就说明这已经是一个正确的顺序的,后面的循环就没必要循环下去了,这样便能提高程序的效率,而我们只需要在冒泡排序的代码中,判断是否这一样都没发生交换即可。

python代码实现如下:

def bubble_sort(numlist):
 # 需要排列的数据个数
 N = len(numlist)
 # i 控制一共需要多少趟 N-1
 for i in range(N-1):
  
  # 定义一个变量,用于记录是否在本趟中发生了交换
  isChange = 0
  
  # j 控制每趟需要比较多少次(因为i是从0开始,所以N-i-1)
  for j in range(N-i-1):
   # 判断j和j+1两个位置的数据大小
   if numlist[j]>numlist[j+1]:
    # 交换(交换的代码有很多种写法)
    temp = numlist[j]
    numlist[j] = numlist[j+1]
    numlist[j+1] = temp
    # 只要发生了交换,我们就改变isChange的值为1
    isChange = 1
  
  # 只要isChange =0说明已经是正确顺序了,直接break即可
  if isChange == 0:
   break
   
list = [19,2,13,8,34,25,7]
print("排序前list = %s"%list)
bubble_sort(list)
print("排序后list = %s"%list)

运行结果为:

排序前list = [19, 2, 13, 8, 34, 25, 7]
排序后list = [2, 7, 8, 13, 19, 25, 34]

C语言代码实现如下:

#include <stdio.h>
// 创建一个冒泡函数,需要传递一个数组,和数组的长度
void bubble_sort(int array[],int arrayLength)
{
 // i 控制一共需要循环多少趟,
 for (int i=0; i<arrayLength-1; i++)
 {
  //定义一个变量,用于记录是否在本趟中发生了改变
  int isChange = 0;
  // j 控制每趟循环多少次
  for (int j=0; j<arrayLength-i-1; j++)
  {
   //判断j和j+1位置上d数的大小
   if (array[j]>array[j+1])
   {
    //交换
    int temp = array[j];
    array[j] = array[j+1];
    array[j+1] = temp;
    // 只要发生了交换,我们就改变isChange的值为1
    isChange = 1;
   }
  }
  // 只要isChange =0说明已经是正确顺序了,直接break即可
  if (isChange == 0)
  {
   break;
  }
 }
}

int main(int argc, const char * argv[])
{
 // 函数的声明
 void bubble_sort(int array[],int arrayLength);
 // 创建一个数组
 int numArray[] = {19,2,13,8,34,25,7};
 //进行排序
 bubble_sort(numArray,7);
 
 printf("打印排序后的数组是:\n");
 for (int i=0; i<7; i++)
 {
  printf("%d ",numArray[i]);
 }
 return 0;
}

运行结果为:

打印排序后的数组是:

2 7 8 13 19 25 34

八、冒泡排序的时间复杂度

最优时间复杂度:O(n) (表示遍历一次发现没有任何可以交换的元素,排序结束。)
最坏时间复杂度:O(n2)

九、冒泡排序算法的稳定性

冒泡排序就是把小的元素往前调或者把大的元素往后调。比较是相邻的两个元素比较,交换也发生在这两个元素之间。所以,如果两个元素相等,是不会再交换的;如果两个相等的元素没有相邻,那么即使通过前面的两两交换把两个相邻起来,这时候也不会交换,所以相同元素的前后顺序并没有改变,所以冒泡排序是一种稳定排序算法。

侯哥语录:我曾经是一个职业教育者,现在是一个自由开发者。我希望我的分享可以和更多人一起进步。分享一段我喜欢的话给大家:"我所理解的自由不是想干什么就干什么,而是想不干什么就不干什么。当你还没有能力说不得时候,就努力让自己变得强大,拥有说不得权利。"

总结

以上所述是小编给大家介绍的python算法与数据结构之冒泡排序实例详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Python 相关文章推荐
python在windows下实现备份程序实例
Jul 04 Python
python进阶教程之循环对象
Aug 30 Python
使用Python编写一个在Linux下实现截图分享的脚本的教程
Apr 24 Python
python数组复制拷贝的实现方法
Jun 09 Python
Python tkinter label 更新方法
Oct 11 Python
python实现在线翻译功能
Mar 03 Python
Python轻量级web框架bottle使用方法解析
Jun 13 Python
Keras 加载已经训练好的模型进行预测操作
Jun 17 Python
tensorflow 动态获取 BatchSzie 的大小实例
Jun 30 Python
Python Selenium模块安装使用教程详解
Jul 09 Python
python3中确保枚举值代码分析
Dec 02 Python
Python实现制作销售数据可视化看板详解
Nov 27 Python
分析运行中的 Python 进程详细解析
Jun 22 #Python
机器学习实战之knn算法pandas
Jun 22 #Python
解决py2exe打包后,总是多显示一个DOS黑色窗口的问题
Jun 21 #Python
pyinstaller打包单个exe后无法执行错误的解决方法
Jun 21 #Python
pyinstaller打包多个py文件和去除cmd黑框的方法
Jun 21 #Python
解决Pyinstaller 打包exe文件 取消dos窗口(黑框框)的问题
Jun 21 #Python
十行代码使用Python写一个USB病毒
Jun 21 #Python
You might like
PHP导出MySQL数据到Excel文件(fputcsv)
2011/07/03 PHP
解析php中获取url与物理路径的总结
2013/06/21 PHP
PHP实现批量检测网站是否能够正常打开的方法
2016/08/23 PHP
PJBlog插件 防刷新的在线播放器
2006/10/25 Javascript
js函数的引用, 关于内存的开销
2012/09/17 Javascript
通过js获取div的background-image属性
2013/10/15 Javascript
利用JQuery和Servlet实现跨域提交请求示例分享
2014/02/12 Javascript
IE浏览器不支持getElementsByClassName的解决方法
2014/08/27 Javascript
js实现百度联盟中一款不错的图片切换效果完整实例
2015/03/04 Javascript
jQuery给动态添加的元素绑定事件的方法
2015/03/09 Javascript
setTimeout内不支持jquery的选择器的解决方案
2015/04/28 Javascript
javascript实现的多个层切换效果通用函数实例
2015/07/06 Javascript
jQuery+CSS3实现点赞功能
2017/03/13 Javascript
node.js express中app.param的用法详解
2017/07/16 Javascript
React 源码中的依赖注入方法
2018/11/07 Javascript
js里面的变量范围分享
2020/07/18 Javascript
从零学Python之hello world
2014/05/21 Python
Python中的urllib模块使用详解
2015/07/07 Python
Python时间获取及转换知识汇总
2017/01/11 Python
Python中定时任务框架APScheduler的快速入门指南
2017/07/06 Python
python3 破解 geetest(极验)的滑块验证码功能
2018/02/24 Python
tensorflow如何批量读取图片
2019/08/29 Python
Python用input输入列表的实例代码
2020/02/07 Python
在python3中实现更新界面
2020/02/21 Python
html5中valid、invalid、required的定义
2014/02/21 HTML / CSS
办理暂住证介绍信
2014/01/11 职场文书
学校大课间活动方案
2014/01/30 职场文书
运动会入场词50字
2014/02/20 职场文书
高中竞选班长演讲稿
2014/04/24 职场文书
党的群众路线对照检查材料思想汇报(学校)
2014/10/04 职场文书
2014年绩效考核工作总结
2014/12/11 职场文书
入党团支部推荐意见
2015/06/02 职场文书
幼儿园卫生保健制度
2015/08/05 职场文书
创业计划书之烤红薯
2019/09/26 职场文书
pandas:get_dummies()与pd.factorize()的用法及区别说明
2021/05/21 Python
详细分析PHP7与PHP5区别
2021/06/26 PHP