插入排序


  1. //直接插入排序
  2. void InsertSort(int*a, int n)//下标从0开始。
  3. {
  4.     int i;
  5.     for(i=1;i<n;i++)
  6.     {
  7.         int j=i-1;
  8.         int temp=a[i];
  9.         while((a[j]>temp)&&(j>=0))
  10.         {
  11.             a[j+1]=a[j];
  12.             j--;
  13.         }
  14.         a[j+1]=temp;
  15.     }
  16.     for(i=0;i<n;i++)
  17.         printf("%d,",a[i]);
  18.     putchar('\n');
  19. }

  20. void InsertSort(int*a, int n)//下标从1开始。
  21. {
  22.     int i;
  23.     for(i=2;i<n;i++)
  24.     {
  25.         int j=i-1;
  26.         a[0]=a[i];
  27.         while((a[j]>a[0])&&(j>=1))
  28.         {
  29.             a[j+1]=a[j];
  30.             j--;
  31.         }
  32.         a[j+1]=a[0];
  33.     }
  34.     for(i=1;i<n;i++)
  35.         printf("%d,",a[i]);
  36.     putchar('\n');
  37. }


点击(此处)折叠或打开

  1. //折半插入排序
  2. void BinaryInsertSort(int* a,int n)//下标从0开始。
  3. {
  4.     int i;
  5.     int j;
  6.     for(i=1;i<n;i++)
  7.     {
  8.     
  9.         int low=0;
  10.         int high=i-1;
  11.         int temp=a[i];
  12.         if(a[i]>=a[i-1])
  13.             continue;
  14.         while(low<=high)
  15.         {
  16.             int mid=(low+high)/2;
  17.             if(a[mid]>a[i])
  18.                 high=mid-1;
  19.             else
  20.                 low=mid+1;
  21.         }
  22.         for(j=i-1;j>=low;j--)
  23.         {
  24.             a[j+1]=a[j];
  25.         }
  26.         a[low]=temp;    
  27.     }
  28.     for(i=0;i<n;i++)
  29.         printf("%d,",a[i]);
  30.     putchar('\n');    
  31. }

  32. void BinaryInsertSortx(int* a,int n)//下标从1开始。
  33. {
  34.     int i;
  35.     int j;
  36.     for(i=2;i<n;i++)
  37.     {
  38.         int low=1;
  39.         int high=i-1;
  40.         if(a[i]>=a[i-1])
  41.             continue;
  42.         a[0]=a[i];
  43.         while(low<=high)
  44.         {
  45.             int mid=(low+high)/2;
  46.             if(a[mid]>a[i])
  47.                 high=mid-1;
  48.             else
  49.                 low=mid+1;
  50.         }
  51.         for(j=i-1;j>=low;j--)
  52.         {
  53.             a[j+1]=a[j];
  54.         }
  55.         a[low]=a[0];
  56.     }
  57.     for(i=1;i<n;i++)
  58.         printf("%d,",a[i]);
  59.     putchar('\n');    
  60. }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值