Welcome 微信登录
编程资源 图片资源库 蚂蚁家优选 PDF转换器

首页 / 操作系统 / 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.  }