时间:2020-11-03 13:32:02 | 栏目:C代码 | 点击:次
外循环
|
1轮
|
2轮
|
3轮
|
4轮
|
||||||
内循环
|
5个数比较4次
|
4个数比较3次
|
3个数比较2次
|
2个数比较1次
|
||||||
7
5
8
6
9
|
1次
|
2次
|
3次
|
4次
|
1次
|
2次
|
3次
|
1 次
|
2次
|
1次
|
7
5
8
6
9
|
7
8
5
6
9
|
7
8
6
5
9
|
7
8
6
9
5
|
8
7
6
9
5
|
8
7
6
9
5
|
8
7
9
6
5
|
8
7
9
6
5
|
8
9
7
6
5
|
9
8
7
6
5
|
|
|
最小的数5沉底,其余4个数继续比较
|
次小数6沉底,其余3个数
|
7沉底,其余2个数比较
|
最后两个数一次比较
|
那么通过这个排序过程,我们了解了怎样去进行排序,那么到底谁是气泡呢,我们可以从中找出答案,那么从大到小进行排序,较大的一些数就是气泡。随着排序的进行,气泡逐步上升。
从这个排序过种中,还可以看出,5个数实际经过4轮就可以了,实践证明,n个数最多需要n-1轮排序就可以了。
3、冒泡排序的程序如下:
4、算法的改进:
从上面的排序的过程可以看出,如果一个已经排好序的一组数或者经过很少的轮数就可以排完这些数,但是循环还是要继续进行,这样设计出的程序浪费了大量的时间,所以对一这个算法我们可以重新设计。
经过修改后的程如下:
二、选择排序
1、排序的基本思想:先从第一个数开始起,用第一个数和其它的数进行比较,如果比第一个数大就交换位置,否则不进行交换,这样经过第一轮比较我们就能够找出最大值放在第一位置,然后从第二个位置起再找次大数,这样依次下去,就可以进行整个数的排序,实践证明,n个数最多需要n-1轮排序就可以了。
2、排序过程举例:
外循环
|
1轮
|
2轮
|
3轮
|
4轮
|
||||||
内循环
|
5个数比较4次
|
4个数比较3次
|
3个数比较2次
|
2个数比较1次
|
||||||
7
5
8
6
9
|
1次
|
2次
|
3次
|
4次
|
1次
|
2次
|
3次
|
1 次
|
2次
|
1次
|
7
5
8
6
9
|
8
5
7
6
9
|
8
5
7
6
9
|
9
5
7
6
8
|
9
7
5
6
8
|
9
7
5
6
8
|
9
8
5
6
7
|
9
8
6
5
7
|
9
8
7
6
5
|
9
8
7
6
5
|
|
|
最大的数9找到,其余4个数找次大数
|
次大数8找到,其余3个数找
|
7找到,其余2个数找
|
最后两个数一次比较
|
三、插入排序
1、插入排序基本思想:(假定从大到小排序)依次从后面拿一个数和前面已经排好序的数进行比较,比较的过程是从已经排好序的数中最后一个数开始比较,如果比这个数,继续往前面比较,直到找到比它大的数,然后就放在它的后面,如果一直没有找到,肯定这个数已经比较到了第一个数,那就放到第一个数的前面。
那么一般情况下,对于采用插入排序法去排序的一组数,可以先选 取第一个数做为已经排好序的一组数。然后把第二个放到正确位置
2、程序的编写如下: