冒泡排序的思想:
1,比较相邻的元素,如果第一个比第二个大,就交换他们两个
2,对每一对相邻的元素做同样的工作,从开始的第一对到结尾的最后一对,在这一点最后的元素应该是最大数
3,针对所有的元素,重复以上的步骤
4,持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较
算法稳定性
void Bobble_Sort(int a[], int n)
{
int i,j,temp;
for(j = 0; j < n - 1; j++)
{
for(i = 0; i < n - 1 - j; i++)
{
if(a[i] > a[i+1])
{
temp = a[i];
a[i] = a[i+1];
a[i+1] = temp;
}
}
}
}
完整代码如下:
#include <stdio.h>
#include <stdlib.h>
#define SIZE 10
void Bobble_Sort(int a[], int n)
{
int i,j,temp;
for(j = 0; j < n - 1; j++)
{
for(i = 0; i < n - 1 - j; i++)
{
if(a[i] > a[i+1])
{
temp = a[i];
a[i] = a[i+1];
a[i+1] = temp;
}
}
}
}
int main()
{
int a[SIZE] = {65,15,21,45,32,16,30,98,78,22};
int i = 0;
int j = 0;
printf("排序之前的结果:\n");
for (i = 0;i < SIZE;i++)
{
printf("%4d",a[i]);
}
printf("\n");
Bobble_Sort(a,SIZE);
printf("排序之后的结果:\n");
for (j = 0;j < SIZE;j++)
{
printf("%4d",a[j]);
}
printf("\n");
return 0;
}
网友评论