首页 互联网 > 正文

c语言冒泡排序法详解(c语言冒泡法排序)

大家好,小甜来为大家解答以下的问题,关于c语言冒泡排序法详解,c语言冒泡法排序这个很多人还不知道,现在让我们一起来看看吧!

1、C语言冒泡排序法的排序规则:将被排序的记录数组R[1..n]垂直排列,每个记录R看作是重量为R.key的气泡。

2、根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。

3、如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。

4、初始 R[1..n]为无序区。

5、第一趟扫描 从无序区底部向上依次比较相邻的两个气泡的重量,若发现轻者在下、重者在上,则交换二者的位置。

6、即依次比较(R[n],R[n-1]),(R[n-1],R[n-2]),…,(R[2],R[1]);对于每对气泡(R[j+1],R[j]),若R[j+1].key

7、 第一趟扫描完毕时,"最轻"的气泡就飘浮到该区间的顶部,即关键字最小的记录被放在最高位置R[1]上。

8、第二趟扫描 扫描R[2..n]。

9、扫描完毕时,"次轻"的气泡飘浮到R[2]的位置上…… 最后,经过n-1 趟扫描可得到有序区R[1..n] 注意: 第i趟扫描时,R[1..i-1]和R[i..n]分别为当前的有序区和无序区。

10、扫描仍是从无序区底部向上直至该区顶部。

11、扫描完毕时,该区中最轻气泡飘浮到顶部位置R上,结果是R[1..i]变为新的有序区。

12、c语言冒泡排序的编程为:#include void sort(int *a,int len){int i=0;int j;int t;for(i=0;ia[j+1]){t=a[j];a[j]=a[j+1];a[j+1]=t;}}}}int main(int argc, char *argv[]){int a[10]={-999,2,3,77,12,88,0,-8,99,100};int i=0;sort(a,10);for(i=0;i<10;i++){printf("%d ",a[i]);}return 0;}。

本文分享完毕,希望对大家有所帮助。

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。