加雪种压力表读数:9.3.1 最简单排序实现

来源:百度文库 编辑:中财网 时间:2024/04/29 20:33:46

9.3 冒泡排序

无论你学习哪种编程语言,在学到循环和数组时,通常都会介绍一种排序算法来作为例子,而这个算法一般就是冒泡排序。并不是它的名称很好听,而是说这个算法的思路最简单,最容易理解。因此,哪怕大家可能都已经学过冒泡排序了,我们还是从这个算法开始我们的排序之旅。

图9-3-1

9.3.1 最简单排序实现

冒泡排序(Bubble Sort)一种交换排序,它的基本思想是:两两比较相邻记录的关键字,如果反序则交换,直到没有反序的记录为止。冒泡的实现在细节上可以很多种变化,我们将分别就3种不同的冒泡实现代码,来讲解冒泡排序的思想。这里,我们就先来看看比较容易理解的一段。

  1. /* 对顺序表L作交换排序(冒泡排序初级版) */
  2. void BubbleSort0(SqList *L)
  3. {
  4. int i,j;
  5. for(i=1;ilength;i++)
  6. {
  7. for(j=i+1;j<=L->length;j++)
  8. {
  9. if(L->r[i]>L->r[j])
  10. {
  11. swap(L,i,j); /* 交换L->r[i]与L->r[j]的值 */
  12. }
  13. }
  14. }
  15. }

这段代码严格意义上说,不算是标准的冒泡排序算法,因为它不满足“两两比较相邻记录”的冒泡排序思想,它更应该是最最简单的交换排序而已。它的思路就是让每一个关键字,都和它后面的每一个关键字比较,如果大则交换,这样第一位置的关键字在一次循环后一定变成最小值。如图9‐3‐2所示,假设我们待排序的关键字序列是{9,1,5,8,3,7,4,6,2},当i=1时,9与1交换后,在第一位置的1与后面的关键字比较都小,因此它就是最小值。当i=2时,第二位置先后由9换成5,换成3,换成2,完成了第二小的数字交换。后面的数字变换类似,不再介绍。

(点击查看大图)图9-3-2它应该算是最最容易写出的排序代码了,不过这个简单易懂的代码,却是有缺陷的。观察后发现,在排序好1和2的位置后,对其余关键字的排序没有什么帮助(数字3反而还被换到了最后一位)。也就是说,这个算法的效率是非常低的。