程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C語言:冒泡法排序一組數,如何優化?

C語言:冒泡法排序一組數,如何優化?

編輯:關於C語言

C語言:冒泡法排序一組數,如何優化?


#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;
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved