文章摘要:c语言如何排序冒泡法
如今很多人在学C语言,但是有不少朋友对它的排序不太了解,所以下面小编给大家介绍c语言如何排序,一起来看看吧。 […]
如今很多人在学C语言,但是有不少朋友对它的排序不太了解,所以下面小编给大家介绍c语言如何排序,一起来看看吧。
c语言排序的方法
交换排序:借鉴了求较大值,最小值的思想,按升序排列的基本过程为:先将第一个数分别与后面的数进行比较,若后面是的数小,则交换和第一个数的位置,否则不交换:这一轮结束之后,则求除了一个最小的放在第一个位置,然后进行第二轮比较,但这种交换效率低。
冒泡排序:将相邻两个数进行交换,重复的过程,一般,如果有N个数进行排序,则需进行N-1起泡。
选择排序:在交换排序的基础上,找出余下的数中的较大值再与地I+1个数进行交换,这样每一轮比较中最多只有一次交换操作,这个算法最多只有N—1次交换操作。
c语言冒泡排序法的排序规则
将被排序的记录数组R[1..n]垂直排列,每个记录R看作是重量为R.key的气泡。根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。
1、初始R[1..n]为无序区。
2、第一趟扫描。从无序区底部向上依次比较相邻的两个气泡的重量,若发现轻者在下、重者在上,则交换二者的位置。即依次比较(R[n],R[n-1]),(R[n-1],R[n-2]),…,(R[2],R[1]);对于每对气泡(R[j+1],R[j]),若R[j+1].key
3、第二趟扫描扫描R[2..n]。扫描完毕时,"次轻"的气泡飘浮到R[2]的位置上……最后,经过n-1趟扫描可得到有序区R[1..n]注意:第i趟扫描时,R[1..i-1]和R[i..n]分别为当前的有序区和无序区。扫描仍是从无序区底部向上直至该区顶部。扫描完毕时,该区中最轻气泡飘浮到顶部位置R上,结果是R[1..i]变为新的有序区。
c语言从大到小排序的方法
1、比较相邻的元素。如果第一个比第二个大,就交换他们两个。
2、对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是较大的数。
3、针对所有的元素重复以上的步骤,除了最后一个。
4、持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。