冒泡排序(C++)

来源:互联网 发布:金猴闹春 知乎 编辑:程序博客网 时间:2024/05/16 06:57

C++的冒泡排序是经典的算法之一 核心思想就是一遍遍的把最大的那个数放到最下面 然后在循环放 像冒泡泡一样的比较

下面的例子使用了个函数指针来定义函数,这样可以先定义函数的风格,然后再定义函数:

代码如下:

[c-sharp] view plaincopyprint?
  1. #include<iostream>
  2. using namespace std;
  3. typedef int (*CompareFunc)(int a,int b);//声明一个函数指针
  4. void BubbleSort(int *ptr,int length,CompareFunc func);//排序函数 套用函数指针
  5. int compare(int,int);//声明比较函数
  6. int main()
  7. {
  8. int array[10] = {15, 2, 6, 6, 58, 6, 13, 6, 6, 78};
  9. BubbleSort(array, 10,compare
  10. );
  11. /*输出*/
  12. for(int i = 0; i < 10; i++)
  13. cout << array[i] << " ";
  14. cout << endl;
  15. return 0;
  16. }
  17. int compare(int a,int b)
  18. {
  19. if(a == b) return 0;
  20. if(a > b) return 1;
  21. return -1;
  22. }
  23. void BubbleSort(int *ptr,int length, CompareFunc func)
  24. {
  25. for(int i = 0; i < length - 1; i++)
  26. {
  27. for(int j = 0; j < length - 1 - i; j++)//把最大的放到最下面 然后再把第二大的放到下面
  28. {
  29. if(func(*(ptr + j), *(ptr + j + 1)) > 0)
  30. {
  31. int temp = *(ptr + j);//如果前面的比后面的大
  32. *(ptr + j) = *(ptr + j + 1);//那么就换位置
  33. *(ptr + j + 1) = temp;
  34. }
  35. }
  36. }
  37. }

基本概念

  冒泡排序的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复以上过程,仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再大于第2个数),将小数放前,大数放后,一直比较到最小数前的一对相邻数,将小数放前,大数放后,第二趟结束,在倒数第二个数中得到一个新的最小数。如此下去,直至最终完成排序。

  由于在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序。

  用二重循环实现,外循环变量设为i,内循环变量设为j。外循环重复9次,内循环依次重复9,8,...,1次。每次进行比较的两个元素都是与内循环j有关的,它们可以分别用a[j]和a[j+1]标识,i的值依次为1,2,...,9,对于每一个i, j的值依次为1,2,...10-i。

  产生

  在许多程序设计中,我们需要将一个数列进行排序,以方便统计,常见的排序方法有冒泡排序,二叉树排序,选择排序等等。而冒泡排序一直由于其简洁的思想方法和比较高的效率而倍受青睐。

  排序过程

  设想被排序的数组R[1..N]垂直竖立,将每个数据元素看作有重量的气泡,根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R,凡扫描到违反本原则的轻气泡,就使其向上"漂浮",如此反复进行,直至最后任何两个气泡都是轻者在上,重者在下为止。

  算法示例

  49 13 13 13 13 13 13 13

  38 49 27 27 27 27 27 27

  65 38 49 38 38 38 38 38

  97 65 38 49 49 49 49 49

  76 97 65 49 49 49 49 49

  13 76 97 65 65 65 65 65

  27 27 76 97 76 76 76 76

  49 49 49 76 97 97 97 97

原创粉丝点击