冒泡排序算法

转载 2016年08月31日 08:39:56

冒泡排序算法思想

两两比较待排序记录的关键字,发现两个记录的次序相反时即进行交换,直到没有反序的记录为止。按照从小到大或者从大到小的顺序进行交换,这样一趟过去后,最大或最小的数字被交换到了最后一位。

冒泡排序算法的运作过程:(从小到大排序)

设数组a[0..n-1]长度为n,

  • 1.比较相邻的前后二个数据,如果前面数据大于后面的数据,就将二个数据交换。

  • 2.这样对数组的第0个数据到n-1个数据进行一次遍历后,最大的一个数据就“沉”到数组第n-1个位置。

  • 3.n=n-1,如果n不为0就重复前面二步,否则排序完成。


例子为从小到大排序,原始待排序数组| 7 | 2 | 4 | 5| 1 |

第一趟排序(外循环)

第一次两两比较7 > 2交换(内循环)

交换前状态| 7 | 2 | 4 | 5 | 1 |

交换后状态| 2 | 7 | 4 | 5 | 1 |

第二次两两比较,7 > 4交换

交换前状态| 2 | 7 | 4 | 5 | 1 |

交换后状态| 2 | 4 | 7 | 5 | 1 |

第三次两两比较,7 > 5交换

交换前状态| 2 | 4 | 7 | 5 | 1 |

交换后状态| 2 | 4 | 5 | 7 | 1 |

第四次两两比较,7 > 1交换

交换前状态| 2 | 4 | 5 | 7 | 1 |

交换后状态| 2 | 4 | 5 | 1 | 7 |

第二趟排序(外循环)

第一次两两比较2 < 4不交换

交换前状态| 2 | 4 | 5 | 1 | 7 |

交换后状态| 2 | 4 | 5 | 1 | 7 |

第二次两两比较,4 < 5不交换

交换前状态| 2 | 4 | 5 | 1 | 7 |

交换后状态| 2 | 4 | 5 | 1 | 7 |

第三次两两比较,5>1交换

交换前状态| 2 | 4 | 5 | 1 | 7 |

交换后状态| 2 | 4 | 1 | 5 | 7 |

第三趟排序(外循环)

第一次两两比较2 < 4不交换

交换后状态| 2 | 4 | 1 | 5 | 7 |

交换后状态| 2 | 4 | 1 | 5 | 7 |

第二次两两比较,4 > 1交换

交换后状态| 2 | 1 | 4 | 5 | 7 |

交换后状态| 2 | 1 | 4 | 5 | 7 |

第四趟排序(外循环)

第一次两两比较2 > 1交换

交换后状态| 2 | 1 | 4 | 5 | 7 |

交换后状态| 1 | 2 | 4 | 5 | 7 |

排序完毕,输出最终结果1 2 4 5 7


冒泡排序时间复杂度,最好情况:数组已有序O(n);最坏情况:数组反序O(n^2),平均时间复杂度:O(n^2)。空间复杂度,冒泡排序是原地排序,空间复杂度为O(1)。冒泡排序算法是稳定的排序算法。

冒泡排序算法伪代码

//冒泡排序
BUBBLE_SORT(A)
{
   for i = length[A] to 2
   {
       for j = 1 to i-1
       {
           if A[j] > A[j+1]
           {
                exchange A[j] and A[j+1];
           }
       }
   }
}

Test

用冒泡排序算法对数组arr[10] = {8, 5, 10, 12, 7, 6, 15, 9, 11, 3};从小到大排序。

    @Test
    public void sort2() {
        Integer arr[] = { 8, 5, 10, 12, 7, 6, 15, 9, 11, 3 };
        for (int h = 0; h < arr.length; h++) {//共进行n-1趟外排序
            for (int k = h+1; k < arr.length ; k++) {//每趟内排序所比较的个数分别为:n\n-1\n-2\...\3\2
                if (arr[h] > arr[k]) {
                    Integer temp = arr[h];
                    arr[h] = arr[k];
                    arr[k] = temp;
                }
            }
        }
        // 输出数组元素
        for (Integer it : arr) {
            System.out.print(it + "   ");
        }
    }

输出

3   5   6   7   8   9   10   11   12   15   

排序算法之(1)——冒泡排序

**【冒泡排序的思想】** 冒泡排序总共进行n-1趟,每一趟扫描总是通过两两比较把大的往后放,所以第一趟即把最大数放在最后面,接着第二趟把第二大数放在倒数第二的位置………….到n-1完成,此时只有一...
  • adminabcd
  • adminabcd
  • 2015年06月06日 10:11
  • 864

请编程实现一个冒泡排序算法?

int [] array = new int ; int temp = 0 ; for (int i = 0 ; i { for (int j = i + 1 ; j { if (ar...
  • X_X_OO
  • X_X_OO
  • 2016年09月13日 19:36
  • 1885

java 排序算法实现 其一:冒泡排序

冒泡排序法的java和C++实现
  • sinat_22013331
  • sinat_22013331
  • 2014年10月17日 11:52
  • 308

冒泡排序算法的c语言实现

冒泡排序(BubbleSort)的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。 然后比较第2个数和第3个数,将小数放前...
  • lickylin
  • lickylin
  • 2012年09月23日 20:49
  • 5959

有意思的算法(一)----冒泡排序

冒泡排序的基本思想是:每次比较两个相邻的元素,如果它们的顺序错误就把他们交换过来。     下面举一个具体的例子来介绍一下冒泡排序。    有12,35,99,18,76五个数进行从大到小的排序,既然...
  • u010853701
  • u010853701
  • 2015年10月30日 20:28
  • 2321

JAVA语言编写的冒泡排序算法

JAVA语言编写的冒泡排序算法
  • ITofwanyifei
  • ITofwanyifei
  • 2014年06月03日 18:27
  • 922

排序算法c语言描述---冒泡排序

排序算法系列学习,主要描述冒泡排序,选择排序,直接插入排序,希尔排序,堆排序,归并排序,快速排序等排序进行分析。 文章规划: 一。通过自己对排序算法本身的理解,对每个方法写个小测试程序。 具体思路分析...
  • hitwhylz
  • hitwhylz
  • 2013年08月05日 22:16
  • 8851

单链表实现冒泡排序算法

下面实现主要采用交换指针的方法,其中附加有单链表及其相关的实现 [cpp] view plain copy #include       struct ...
  • zhengqijun_
  • zhengqijun_
  • 2016年10月15日 19:54
  • 1582

排序算法系列:冒泡排序与双向冒泡排序

**排序算法**应该算是一个比较热门的话题,在各个技术博客平台上也都有一些博文进行了一定程度的讲解。但还是希望能从自我完善的角度出发,可以更详细、全面、形象地表达这些算法的精髓。本文就先从最简单的冒泡...
  • u013761665
  • u013761665
  • 2016年01月29日 15:25
  • 9733

改进版的冒泡排序(双向冒泡算法)

#include "stdafx.h" #include #include   //一般的冒泡排序 void bubbleSort(int a[], i...
  • Game_jqd
  • Game_jqd
  • 2016年02月02日 20:37
  • 641
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:冒泡排序算法
举报原因:
原因补充:

(最多只允许输入30个字)