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

排序算法

时间:2015-07-26 19:01:52      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:

1.冒泡排序

void bubblesort(int num[],const int len)
{
    if (len <= 1) return;

    bool sign = false;
    int i, j, tmp;

    for ( i = 0; i < len - 1; i++)
    {
        sign = false;
        for ( j = len - 1; j > i; j--)
        {
            if (num[j] < num[j - 1])
            {
                sign = true; //本轮循环存在排序操作
                tmp = num[j - 1];
                num[j - 1] = num[j];
                num[j] = tmp;
            }
        }
        if (!sign) break; //本轮循环排序已经结束
    }
}

最好时间复杂度为O(n),最差和平均时间复杂度均为O(n^2),稳定排序。

2.直接插入排序

void insertsort(int num[],const int len)
{
    if (len <= 1) return;

    int i, j, temp;

    for ( i = 1; i < len; i++)
    {
        if (num[i] < num[i - 1])
        {
            temp = num[i];
            for (j = i - 1; j >= 0 && num[j] > temp; j--)
            {
                num[j + 1] = num[j];
            }
            num[j + 1] = temp;
        }
    }
}

引用自:http://www.cnblogs.com/heyuquan/p/insert-sort.html中解释

设数组为a[0…n]。

  1. 将原序列分成有序区和无序区。a[0…i-1]为有序区,a[i…n] 为无序区。(i从1开始)
  2. 从无序区中取出第一个元素,即a[i],在有序区序列中从后向前扫描。
  3. 如果有序元素大于a[i],将有序元素后移到下一位置。
  4. 重复步骤3,直到找到小于或者等于a[i]的有序元素,将a[i]插入到该有序元素的下一位置中。
  5. 重复步骤2~4,直到无序区元素为0

时间复杂度:最好O(n),最差、平均都是O(n)。

 

排序算法

标签:

原文地址:http://www.cnblogs.com/jason1990/p/4678171.html

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