码迷,mamicode.com
首页 > 编程语言 > 详细

C# 直接插入排序

时间:2017-09-07 13:23:07      阅读:239      评论:0      收藏:0      [点我收藏+]

标签:[]   开始   代码   有序表   com   archive   pre   bsp   依次   

直接插入排序(straight insertion sort)的作法是:

 

  每次从无序表中取出第一个元素,把它插入到有序表的合适位置,使有序表仍然有序。

 

  第一趟比较前两个数,然后把第二个数按大小插入到有序表中; 第二趟把第三个数据与前两个数从后向前扫描,把第三个数按大小插入到有序表中;依次进行下去,进行了(n-1)趟扫描以后就完成了整个排序过程。

 

  直接插入排序属于稳定的排序,时间复杂性为o(n^2),空间复杂度为O(1)。

 

  直接插入排序是由两层嵌套循环组成的。外层循环标识并决定待比较的数值。内层循环为待比较数值确定其最终位置。直接插入排序是将待比较的数值与它的前一个数值进行比较,所以外层循环是从第二个数值开始的。当前一数值比待比较数值大的情况下继续循环比较,直到找到比待比较数值小的并将待比较数值置入其后一位置,结束该次循环。

 

  值得注意的是,我们必需用一个存储空间来保存当前待比较的数值,因为当一趟比较完成时,我们要将待比较数值置入比它小的数值的后一位 插入排序类似玩牌时整理手中纸牌的过程。插入排序的基本方法是:每步将一个待排序的记录按其关键字的大小插到前面已经排序的序列中的适当位置,直到全部记录插入完毕为止。

  

  •      第一层循环是为了依次将数组中的值放入到有序表里,这里循环是从1开始,第1个元素就是有序表。比如循环进到了5,那么前五个元素就是有序表,后面的就是无序表
  •      第二层循环是为了形成有序表,第一次外层循环,都有一个元素放到有序表中,并形成新的有序表。

    C#代码:(我写的不是很简练)

 

public class SortHelper
    {
        public static void InsertSort<T>(T[] array) where T : IComparable
        {
            int length = array.Length;
            for (int i = 1; i < length; i++)
            {
                T temp = array[i];
                if (temp.CompareTo(array[i - 1])<0)
                {
                    for (int j = 0; j < i; j++)
                    {
                        if (temp.CompareTo(array[j])<0)
                        {
                            temp = array[j];
                            array[j] = array[i];
                            array[i] = temp;
                        }
                    }
                }
            }
        }
    }

http://www.cnblogs.com/criedshy/archive/2010/05/05/1728070.html

C# 直接插入排序

标签:[]   开始   代码   有序表   com   archive   pre   bsp   依次   

原文地址:http://www.cnblogs.com/tianciliangen/p/7489067.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!