您的位置:首页 > 编程语言 > C语言/C++

C语言:冒泡法排序一组数,如何优化?

2015-11-13 16:28 357 查看
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>

int main()
{
int arr[] = { 5, 6, 7, 8, 9 ,1, 2, 3, 4};
int i = 0;
int j = 0;
int flag;
int size = sizeof(arr) / sizeof(arr[0]);
for (i = 0; i < size- 1 ; i++)
{
flag = 1;//设置标志位,优化冒泡
for (j = 0; j < size  - 1 - i ; j++)
{
if (arr[j] < arr[j + 1])
{
int tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
flag = 0;
}
}
if (flag) //说明未进入if内部,即尚未交换已经是所需的输出顺序
break;
}

for (i = 0; i < size; i++)
{
printf("%d ", arr[i]);
}
system("pause");
return 0;
}


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息