• 算法导论—排序之插入排序




    void insertion_sort(vector<int> &num){
        for(int i = 1; i < num.size(); i++){
            int j = i-1;
            int val = num[i];
            while(j>=0 && num[j] >= val){
                num[j+1] = num[j];
                j--;
            }
            num[j+1] = val;
        }
    
    
    }

    每次迭代时,将num[i] 作为key值。且前子数组[0,i-1] 构成已排好序。每次与左边的数比較。未满足条件。则进行右移


    //降序
    void insertion_sort(vector<int> &num){
        for(int i = 1; i < num.size(); i++){
            int j = i-1;
            int val = num[i];
            while(j>=0 && num[j] < val){
                num[j+1] = num[j];
                j--;
            }
            num[j+1] = val;
        }
    
    
    }

    效率分析:

    最优情况:

    原数列已排好序,即不进行while循环,效率为 n

    最差情况:

    原数列为逆序,则每次迭代要进行i-1次循环,则效率为  n方

  • 相关阅读:
    结构体struct和typedef后面接指针的含义
    C++中关于指针初始化和使用NULL的理解
    (虚)继承类的内存占用大小
    为什么构造函数不能为虚函数
    C++中变量自动初始化的问题
    CY7C68013A的一点总结
    Altium designer总结
    在Linux系统上限制远程登录的IP
    linux系统如何限制其他用户登录
    使用秘钥对登录Linux系统
  • 原文地址:https://www.cnblogs.com/ldxsuanfa/p/10940502.html
  • Copyright © 2020-2023  润新知