首页 > 编程语言 > 详细

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

时间:2015-11-13 19:12:11      阅读:340      评论:0      收藏:0      [点我收藏+]
#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;
}

技术分享

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

原文:http://10740184.blog.51cto.com/10730184/1712544

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!