歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

C語言算法--插入排序

C語言算法--插入排序

  1. /*----------------------------- 
  2. * For    排序算法學習 
  3. * IDE    DEV-CPP4.9.2 
  4. * Auhtor  Czp 
  5. * Date   2012/10/17 
  6. *------------------------------ 
  7. */ 
  8. #include <stdlib.h>  
  9. #include <stdio.h>  
  10. //插入排序  
  11. void insertSort(int* arr,size_t n)       
  12.        
  13.       int i,j,key; 
  14.       for(i=1;i<n;i++)                      //初始:ar={169,45,2,489,469,4,-778,156}  
  15.       {                                     
  16.           key = arr[i];                   
  17.           j=i-1; 
  18.           while(j>=0&&arr[j]>key)          //把key與前面的arr[0~j]進行比較   
  19.                   arr[j+1] = arr[j--];     //找到一個比key大的數就把它後移   
  20.           arr[j+1]=key;                    //上面的循環終止,則j+1就key的位置   
  21.       }   
  22.       /* 
  23.       *Loop0:169,45,2,489,469,4,-778,156  數組原型  取key=arr[2]=2  
  24.       *Loop1:2,169,45,489,469,4,-778,156  key=2比arr[1] arr[0]小,找到arr[2]的位置arr[0]-> 
  25.       *Lopp3:2,169,45,469,489,4,-778,156  進行插入和ArrayList的insert(value,index)一樣  
  26.       *Loop4:2,169,45,469,489,4,-778,156  ....... 
  27.       *Loop5:2,4,169,45,469,489,-778,156  ... 
  28.       *Loop6:-778,2,4,169,45,469,489,156  ... 
  29.       *Loop7:-778,2,4,156,169,45,469,489  ... 
  30.       */ 
  31. }   
  32.  
  33.  int main(int argc, char *argv[]) 
  34.  { 
  35.      int arr[] = {169,45,2,489,469,4,-778,156}; 
  36.      size_t len = (sizeof arr/sizeof arr[0]); 
  37.      insertSort(arr,len); 
  38.      int i; 
  39.      for(i=0;i<len;i++) 
  40.      { 
  41.          printf("%d ,",arr[i]);                 
  42.      } 
  43.      //====>-778,2,4,156,169,45,469,489  
  44.      getchar(); 
  45.      return 0; 
  46.  } 
Copyright © Linux教程網 All Rights Reserved