9.3.2 冒泡排序算法

我们来看看正宗的冒泡算法,有没有什么改进的地方。

/* 对顺序表L作冒泡排序 */void BubbleSort(SqList *L){ int i,j;for(i=1;i<L->length;i++){for(j=L->length-1;j>=i;j--)   /* 注意j是从后往前循环 */{if(L->r[j]>L->r[j+1])  /* 若前者大于后者(注意这里与上一算法差异)*/{swap(L,j,j+1);  /* 交换L->r[j]与L->r[j+1]的值 */}}}}

依然假设我们待排序的关键字序列是{9,1,5,8,3,7,4,6,2},当i=1时,变量j由8反向循环到1,逐个比较,将较小值交换前面,直到最后找到最小值放置在了第1的位置。如图9-5-3,当i=1,j=8时,我们发现6>2,因此交换了它们的位置,j=7时,4>2,所以交换……直到j=2时,因为1<2,所在不交换。j=1时,9>1,交换,最终得到最小值1放置第一的位置。事实上,在不断循环的过程中,除了将关键字1放到第一的位置,我们还将关键字2从第九位置提到到了第三的位置,显然这一算法比前面的要有进步,在上十万条数据的排序过程中,这种差异会体现出来。图中较小的数字如同气泡般慢慢浮到上面,因此就将此算法命名为冒泡算法。

当i=2时,变量j由8反向循环到2,逐个比较,在将关键字2交换到第二位置的同时,也将关键字4和3有所提升。

后面的数字变换很简单,这里就不在赘述了。

9.3.3 冒泡排序优化
        这样的冒泡程序是否还可以优化呢?答案是肯定的。试想一下,如果我们待排序的序列是{2,1,3,4,5,6,7,8,9},也就是说,除了第一和第二的关键字需要交换外,别的都已经是正常的顺序。当i=1时,交换了2和1,此时序列已经有序,但是算法仍然不依不饶的将i=2到9,以及每个循环中的j循环都执行了一遍,尽管并没有交换数据,但是之后的大量比较还是大大的多余了。

当i=2时,我们已经对9与8,8与7,……,3与2作了比较,没有任何数据交换,这就说明此序列已经有序,不需要再继续后面的循环判断工作了。为了实现这个想法,我们需要改进一下代码,增加一个标记变量flag,来实现这一算法的改进。

/* 对顺序表L作改进冒泡算法 */void BubbleSort2(SqList *L){ int i,j;Status flag=TRUE;     /* flag用来作为标记 */for(i=1;i<L->length && flag;i++)  /*若flag为true则有过数据交换,否则退出循环*/{flag=FALSE;     /* 初始为false */for(j=L->length-1;j>=i;j--){if(L->r[j]>L->r[j+1]){swap(L,j,j+1);  /* 交换L->r[j]与L->r[j+1]的值 */flag=TRUE;   /* 如果有数据交换,则flag为true */}}}}

代码改动的关键就是在i变量的for循环中,增加了对flag是否为true的判断。经过这样的改进,冒泡排序在性能上就有了一些提升,可以避免因已经有序的情况下的无意义循环判断。

9.3.4 冒泡排序复杂度分析
        分析一下它的时间复杂度。当最好的情况,也就是要排序的表本身就是有序的,那么我们比较次数,根据最后改进的代码,可以推断出就是n-1次的比较,没有数据交换,时间复杂度为O(n)。当最坏的情况,即待排序表是逆序的况,此时需要比较 次,并作等数量级的记录移动。因此,总的时间复杂度为O(n2)。

出处:http://www.cnblogs.com/cj723/archive/2011/04/15/2016689.html

《大话数据结构》第9章 排序 9.3 冒泡排序(下)相关推荐

  1. 大话数据结构 第七章 图(二) 最小生成树、最短路径、拓扑排序、关键路径算法

    大话数据结构 第七章 图(二) 最小生成树.最短路径.拓扑排序.关键路径算法 最小生成树 定义 Prim算法 Kruskal算法 最短路径 Dijkstra算法 Floyd算法 拓扑排序 AOV网 拓 ...

  2. 《大话数据结构》样章试读

    <大话数据结构>样章试读 各位童鞋,<大话数据结构>从写作到出版,虽然经历了一些坎坷,但终于还是在今天正式在一些网店发售了.现在提供两章的完整版试读PDF文件,希望能给您有所 ...

  3. 《大话数据结构》第9章 排序 9.3 冒泡排序(上)

    9.3.1 最简单排序实现 无论你学习哪种编程语言,在学到循环和数组时,通常都会介绍一种排序算法来作为例子,而这个算法一般就是冒泡排序.并不是它的名称很好听,而是说这个算法的思路最简单,最容易理解.因 ...

  4. 读书笔记-《大话数据结构》第二章算法

    2.3两种算法的比较 #include <iostream> #if 0 //需要运行 100次 int main() {int i,sum=0,n=100;for(i=1;i<=n ...

  5. 【大话数据结构算法】希尔排序

    希尔排序的实质就是分组插入排序,该方法又称为缩小增量排序. 直接插入排序适合于序列基本有序的情况,希尔排序的每趟排序都会使整个序列变得更加有序,等整个序列基本有序了,再来一趟直接插入排序,这样会使排序 ...

  6. 大话数据结构 摘录 第一章 数据结构绪论

    文章目录 启示:数据结构 学习数据机构的重要性 数据结构引发的案例 数据结构的起源 程序设计=数据结构+算法 基础概念与术语 数据 数据元素 数据项 数据对象 数据结构 数据结构:是相互之间存在一种或 ...

  7. 读书笔记-《大话数据结构》第一章数据结构绪论

    1.3数据结构的起源 数据结构:是一门研究非数值计算的程序设计问题中的操作对象,以及它们之间的关系和操作等相关问题的学科. 程序设计=数据结构+算法 1.4基本概念和术语 1.4.1数据:描述客观事物 ...

  8. 大话数据结构第四章栈的应用

    一.斐波契那数列 就是下一项的值等于相邻的上两项元素之和. 这个规律就是斐波契那数列.由此,我知道这个世界是少不了规律的.就算没有规律也要用规律来逼近描述无规律的现象. 迭代和递归的区别:迭代是循环, ...

  9. 大话数据结构第四章栈的基本概念与出栈入栈操作

    一.栈的顺序存储结构 1.基本概念 栈顶就是表尾. 栈顶是栈插入和删除的地方. 栈就是只允许在表尾进行添加或删除,是顺序存储结构线性表的特例或者说简化. 为什么说是简化呢?相对于顺序存储结构来说栈只允 ...

最新文章

  1. 年前整理的Css规范
  2. 借入单的后续处理-借入归还
  3. [操作系统实验lab4]实验报告
  4. PL/SQL 训练12--动态sql和绑定变量
  5. 使用VNC远程安装CentOS 7操作系统
  6. 【数据结构】栈的基本操作
  7. 手机群控系统电脑/手机硬件配置相关测试参数
  8. 7万字总结Spring,这回能看懂Spring源码了!
  9. 如何快速批量修改图片名称?
  10. python3爬取教务系统的个人学期课程表(无头谷歌浏览模拟登录)
  11. texstudio 使用方法_Texstudio使用技巧——基于个人
  12. js使用moment获取当前日期是当前月的第几周
  13. DelphiXE7操作sqlite数据库
  14. 影响计算机速度的有哪些配件,影响电脑上网速度的重要因素有哪些?
  15. Java中isBlank()和isEmpty()的区别
  16. php实现24点游戏,24点游戏的开发和实现(VC++)
  17. 【计算几何】圆的面积并
  18. 计算机趣味数学社团活动管理制度,趣味数学社团活动方案
  19. UILabel行间距调整
  20. 后端图片存储绝对路径,Vue前端展示报错

热门文章

  1. 并发编程-23J.U.C组件拓展之阻塞队列BlockingQueue 和 线程池
  2. wordpressPHP实现ajax评论,AJAX_wordpress 为主题添加AJAX提交评论功能的php代码,首先需要在主题的function.php文 - phpStudy...
  3. jquery.ajax上传个数限制,关于jquery ajax上传的坑
  4. Linux如何在任务栏显示时间,在MFC[转载]在MFC状态栏显示时间 状态栏显示时间
  5. 如何用pip指令将python包安装到虚拟环境中
  6. c++ dump某个变量_linux内核调试之 crash分析dump文件
  7. 超市管理系统java swing+mysql报告_基于java+swing+mysql的超市管理系统
  8. 数据结构实验之串三:KMP应用
  9. 3.在slave1机器下载3个安装包解压后,复制给master机器
  10. 2、UNIX、Linux操作系统的发展历程、介绍、应用领域