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

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

    这段代码严格意义上说,不算是标准的冒泡排序算法,因为它不满足“两两比较相邻记录”的冒泡排序思想,它更应该是最最简单的交换排序而已。它的思路就是让每一个关键字,都和它后面的每一个关键字比较,如果大则交换,这样第一位置的关键字在一次循环后一定变成最小值。如图9-3-2所示,假设我们待排序的关键字序列是{9,1,5,8,3,7,4,6,2}
    ,当i=1时,9与1交换后,在第一位置的1与后面的关键字比较都小,因此它就是最小值。当i=2时,第二位置先后由9换成5,换成3,换成2,完成了第二小的数字交换。后面的数字变换类似,不再介绍。
    image.png
    它应该算是最最容易写出的排序代码了,不过这个简单易懂的代码,却是有缺陷的。观察后发现,在排序好1和2的位置后,对其余关键字的排序没有什么帮助(数字3反而还被换到了最后一位)。也就是说,这个算法的效率是非常低的。