首页 > 编程语言 > 详细

数据结构与算法——插入排序与希尔排序

时间:2016-12-18 01:31:42      阅读:150      评论:0      收藏:0      [点我收藏+]

void Insertsort(int a[], int n)
{
    int i, j;
    int Tmp;
    for (i = 1; i < n; i++)//from the second element
        for (j = i - 1; j >= 0 && a[j] > a[j + 1]; j--){  //from the i-1 begin to compare until the first element
            Tmp = a[j];
            a[j] = a[j + 1];
            a[j + 1] = Tmp;
        }
}
//The time complexity of the insertion sort is O(N2).

void shellsort(int a[], int n)
{
    int i, j, gap;
    int Tmp;

    for (gap = n / 2; gap > 0; gap /= 2)// an additional loop here
        for (i = gap; i < n; i++)
            for (j = i - gap; j >= 0 && a[j] > a[j + gap]; j -= gap){
                Tmp = a[j];
                a[j] = a[j + gap];
                a[j + gap] = Tmp;
            }//modify the "1" to "gap"
}
//The insertion sort is the special situation in which the gap is 1

数据结构与算法——插入排序与希尔排序

原文:http://www.cnblogs.com/Vincent-Zy/p/6193346.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!