Chinaunix首页 | 论坛 | 博客
  • 博客访问: 26744
  • 博文数量: 41
  • 博客积分: 185
  • 博客等级: 入伍新兵
  • 技术积分: 260
  • 用 户 组: 普通用户
  • 注册时间: 2012-12-20 13:48
文章分类

全部博文(41)

文章存档

2013年(20)

2012年(21)

我的朋友
最近访客

分类: C/C++

2013-01-04 22:23:10

直接插入排序的基本思想
直接插入排序的基本思想是:把n个待排序的元素看成为一个有序表和一个无序表,开始时有序表中只包含一个元素,无序表中包含有n-1个元素,排序过程中每次从无序表中取出第一个元素,将它插入到有序表中的适当位置,使之成为新的有序表,重复n-1次可完成排序过程。
把a[i]插入到a[0],a[1],...,a[i-1]之中的具体实施过程为:先把a[i]赋值给变量t,然后将t依次与a[i-1],a[i-2],...进行比较,将比t大的元素右移一个位置,直到发现某个j(0<=j<=i-1),使得a[j]<=t或j为(-1),把t赋值给a[j+1].

点击(此处)折叠或打开

  1. void insert_sort(int a[],int n)
  2. {
  3.     int i,j,temp;
  4.     for(i=1;i<n;i++) //i表示插入次数,共进行n-1次插入;
  5.     {
  6.         temp=a[i]; //把待排序元素赋给temp;
  7.         j=i-1;
  8.         while((j>=0)&&(temp<a[j])) //顺序比较和移动;
  9.         {
  10.             a[j+1]=a[j];
  11.             j--;
  12.         }
  13.         a[j+1]=temp;
  14.     }
  15. }


阅读(276) | 评论(0) | 转发(0) |
0

上一篇:直接插入排序原理

下一篇:链表逆序

给主人留下些什么吧!~~