Dev@Free

zJun's Tech Weblog

[排序] 插入排序

插入排序,好比是洗扑克一样,我们将牌分作两堆,每次从后面一堆的牌抽出最前端的牌,然后插入前面一堆牌的适当位置,例如:

排序前: [92], 77, 67, 8, 6, 84, 55, 85, 43, 67  -- 将数组分为两部分,第一个元素为一组

第 1 次排序:[77 92] 67 8 6 84 55 85 43 67     -- 将后一组的第一个元素 77 插入前一组的适当位置
第 2 次排序:[67 77 92] 8 6 84 55 85 43 67     -- 将后一组的第一个元素 67 插入前一组的适当位置
第 3 次排序:[8 67 77 92] 6 84 55 85 43 67     -- 将后一组的第一个元素 8 插入前一组的适当位置 
第 4 次排序:[6 8 67 77 92 84] 55 85 43 67      -- 将后一组的第一个元素 6 插入前一组的适当位置
第 5 次排序:[6 8 67 77 84 92 55] 85 43 67      -- 将后一组的第一个元素 84 插入前一组的适当位置
第 6 次排序:[6 8 55 67 77 84 92 85] 43 67      -- 将后一组的第一个元素 55 插入前一组的适当位置
第 7 次排序:[6 8 55 67 77 84 85 92 43] 67      -- 将后一组的第一个元素 85 插入前一组的适当位置
第 8 次排序:[6 8 43 55 67 77 84 85 92] 67      -- 将后一组的第一个元素 43 插入前一组的适当位置
第 9 次排序:[6 8 43 55 67 67 77 84 85 92]      -- 将后一组的第一个元素 67 插入前一组的适当位置

Java代码实现,如下:

/**  
  * 插入排序
  *  
@param   data:等代排序整型数组
  *     data = { 92, 77, 67, 8, 6, 84, 55, 85, 43, 67 }
  *     排序结果:
  *        第 1 次排序:77 92 67 8 6 84 55 85 43 67 
  *        第 2 次排序:67 77 92 8 6 84 55 85 43 67 
  *        第 3 次排序:8 67 77 92 6 84 55 85 43 67 
  *        第 4 次排序:6 8 67 77 92 84 55 85 43 67 
  *        第 5 次排序:6 8 67 77 84 92 55 85 43 67 
  *        第 6 次排序:6 8 55 67 77 84 92 85 43 67 
  *        第 7 次排序:6 8 55 67 77 84 85 92 43 67 
  *        第 8 次排序:6 8 43 55 67 77 84 85 92 67 
  *        第 9 次排序:6 8 43 55 67 67 77 84 85 92 
   
*/
 
public   void  insertSort( int  data[])  {
        
int  k, temp, max  =  data.length;

        
for  ( int  i  =   1 ; i  <  max; i ++ {
            temp 
=  data[i];  //  后一组的第一个元素
            k  =  i  -   1 //  从前一组的最后一个元素开始比较
             while  (temp  <  data[k])  {
                data[k 
+   1 =  data[k];  //  如果前一组元素大于后一组第一个元素,则后移
                k -- ;
                
if  (k  ==   - 1 )
                    
break //  如果前一组元素比较完,则跳出
            }

            data[k 
+   1 =  temp;  //  插入适当的位置

            System.out.print(
"  第   "   +  i  +   "   次排序:  " );
            
for  ( int  j  =   0 ; j  <=  max  -   1 ; j ++ {
                System.out.print(data[j] 
+   "     " );
            }

            System.out.println();
        }

    }

posted on 2006-07-10 14:32 zJun's帛罗阁 阅读(504) 评论(0)  编辑  收藏


只有注册用户登录后才能发表评论。


网站导航:
 

导航

<2006年7月>
2526272829301
2345678
9101112131415
16171819202122
23242526272829
303112345

统计

常用链接

留言簿(15)

随笔分类

随笔档案

相册

收藏夹

博客

文档

站点

论坛

搜索

积分与排名

最新评论

阅读排行榜

评论排行榜