冒泡排序:
思路:
(1):将相邻的两个数比较,将较小的数调到前头;
(2):有n个数就要进行n-1趟比较;
(3):第一次比较中要进行n-1次两两比较,在第j趟比较中,要进行n-j次两两比较;
例子为从小到大排序,
原始待排序数组| 6 | 2 | 4 | 1 | 5 | 9 |
第一趟排序(外循环)
第一次两两比较6 > 2交换(内循环)
交换前状态|
6 |
2 | 4 | 1 | 5 | 9 |
交换后状态|
2 |
6 | 4 | 1 | 5 | 9 |
第二次两两比较,6 > 4交换
交换前状态| 2 |
6 |
4 | 1 | 5 | 9 |
交换后状态| 2 |
4 |
6 | 1 | 5 | 9 |
第三次两两比较,6 > 1交换
交换前状态| 2 | 4 |
6 |
1 | 5 | 9 |
交换后状态| 2 | 4 |
1 |
6 | 5 | 9 |
第四次两两比较,6 > 5交换
交换前状态| 2 | 4 | 1 |
6 |
5 | 9 |
交换后状态| 2 | 4 | 1 |
5 |
6 | 9 |
第五次两两比较,6 < 9不交换
交换前状态| 2 | 4 | 1 | 5 | 6 | 9 |
交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |
第二趟排序(外循环)
第一次两两比较2 < 4不交换
交换前状态| 2 | 4 | 1 | 5 | 6 | 9 |
交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |
第二次两两比较,4 > 1交换
交换前状态| 2 |
4 |
1 | 5 | 6 | 9 |
交换后状态| 2 |
1 |
4 | 5 | 6 | 9 |
第三次两两比较,4 < 5不交换
交换前状态| 2 | 1 | 4 | 5 | 6 | 9 |
交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |
第四次两两比较,5 < 6不交换
交换前状态| 2 | 1 | 4 | 5 | 6 | 9 |
交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |
第三趟排序(外循环)
第一次两两比较2 > 1交换
交换后状态|
2 |
1 | 4 | 5 | 6 | 9 |
交换后状态|
1 |
2 | 4 | 5 | 6 | 9 |
第二次两两比较,2 < 4不交换
交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |
交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |
第三次两两比较,4 < 5不交换
交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |
交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |
第四趟排序(外循环)无交换
第五趟排序(外循环)无交换
排序完毕,输出最终结果1 2 4 5 6 9
程序代码:
void BublleSort ( int arr [], int count )
int i, j, temp;
for(j = 0; j < count-1; j ) /* 冒泡法要排序n-1次*/
{
for(i = 0; i < count-j-1; i )/* 值比较大的元素沉下去后,只把剩下的元素中的最大值再沉下去就可以啦 */
{
if(arr[i]>arr[i + 1])/* 把值比较大的元素沉到底 */
{
temp=arr[i + 1]; //先存放被赋予值的变量, 不然如果先赋予值,那么之前的值就会丢失了
arr[i + 1]=arr[i];
arr[i]=temp;
}
}
}
}
阅读(1223) | 评论(0) | 转发(0) |