大家好,小甜来为大家解答以下的问题,关于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 本文分享完毕,希望对大家有所帮助。