zoukankan      html  css  js  c++  java
  • 排序算法总结

      1.冒泡排序

      相邻两个交换

      时间复杂度O(n²)

      稳定

      2.插入排序

        O(n²)

      稳定

      3.选择排序

      O(n²)

      不稳定

      4.快排

      1)从待排序的n个记录中任意选取一个记录(通常选取第一个记录)为分区标准;

      2)把所有小于该排序列的记录移动到左边,把所有大于该排序码的记录移动到右边,中间放所选记录,称之为第一趟排序;

      3)然后对前后两个子序列分别重复上述过程,直到所有记录都排好序。

      稳定性:不稳定

      平均时间复杂度:O(nlogn)

      

      5.归并

      1)先通过二分将其分到最小,再合并有序数组

      O(nlogn) 稳定

    void Merge(int *a, int *l, int*r, int m, int n)
    {
        int i = 0, j = 0,k=0;
        while (i < m&&j < n)
        {
            if (l[i] < r[j]) a[k++] = l[i++];
            else
            {
                a[k++] = r[j++];
            }
        }
        while (i < m) a[k++] = l[i++];
        while (j < n)a[k++] = r[j++];
    }
    
    
    void MergeSort(int *a, int n)
    {
        int mid, i, *l, *r;
        if (n < 2) return;
        mid = n / 2;
        l = new int[mid];
        r = new int[n - mid];
        for (i = 0; i < mid; i++) l[i] = a[i];
        for (i = mid; i < n; i++) r[i - mid] = a[i];
        MergeSort(l, mid);
        MergeSort(r, n - mid);
        Merge(a, l, r, mid, n - mid);
        delete[] r;
        delete[] l;
    }

       
      6.堆排序

      时间复杂度O(nlogn)

      不稳定

      

    void buildminHeap(vector<int>&a,int i)//建堆
    {
        int temp = a[i];//挖坑
        for (; i != 0;)
        {
            if (temp < a[(i - 1) / 2])
            {
                a[i] = a[(i - 1) / 2];//填坑
                i = (i - 1) / 2;
            }
            else
                break;
        }
        a[i] = temp;
    }
    
    void minHeap(vector<int> a, vector<int> &res)
    {
        for (int i = 0; i < a.size(); i++)
        {
            res[i] = a[i];
            buildminHeap(res, i);
        }
    }
    
    vector<int> removeminHeap(vector<int> a)
    {
        int n = a.size();
        vector<int> res;
        res.resize(a.size(), 0);
        for (int i = 0; i <n ; i++)
        {
            res[i] = a[0];
            a[0] = a[a.size() - 1];
            a.erase(a.end() - 1);
            int j = 0,k=2*j+1;
            while (1)
            {
                k = 2 * j + 1;
                if ((k+1) > a.size() && k < a.size())//没有右子树
                {
                    int temp = a[j];
                    a[j] = a[k];
                    a[k] = temp;
                }
                else if (k < a.size() && (k+1)< a.size())//左右子树存在
                {
                    int t = a[k] < a[k+1] ? (k) : (k+1);    //取小的
                    int temp = a[t];
                    a[t] = a[j];
                    a[j] = temp;
                    j = t;
                }
                else
                    break;
            }
        }
        return res;
    }

      7.桶排序

      O(n+C) 稳定

  • 相关阅读:
    流式布局
    发送短信验证码 倒计时
    jQuery-qrcode.js 生成带Logo 的二维码
    bootstrap-daterangepicker插件运用
    html 转 pdf
    input placeholder 在chrome 浏览器自动填充时,背景色覆盖原有背景图片问题。
    jQuery.qrcode 生成二维码,并使用 jszip、FileSaver 下载 zip 压缩包至本地。
    java学习之super、final、static关键字及匿名对象
    java学习之数组
    java学习之循环语句
  • 原文地址:https://www.cnblogs.com/wshr007/p/11492531.html
Copyright © 2011-2022 走看看