码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • CSDN21天学习挑战赛之插入排序


    ​

    活动地址:CSDN21天学习挑战赛

    “九层之台,起于垒土”。学习技术须脚踏实地。

    插入排序的概念

    插入排序是一种较基础的排序算法,原理也简单易懂,只要会玩扑克就应该能很快学会。

    1.直接插入排序

    直接插入排序通过构建有序序列,依次扫描无序序列的每个元素,将其与有序序列比较,插入小于自身的元素后面,其余元素依次后移。

    动图演示:
    请添加图片描述
    参考:菜鸟教程

    ​c++实现:

    template<typename T>
    void direct_insert_sort(T* arr, int len){
        for(int i = 1;i < len;i++){
            T temp = arr[i];
            int j = i - 1;
            while(j != -1 && temp < arr[j]){
                arr[j + 1] = arr[j];
                --j;
            }
            arr[++j] = temp;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    2.希尔排序

    希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。

    由于插入排序具有以下两点性质:

    • 插入排序在对几乎已经排好序的数据操作时,需要的元素访问与元素移位操作少。
    • 直接插入排序每次只能插入一位。

    所以可以先把元素分成几组,在每一组内直接插入排序。然后减少间距,形成新的分组,进行排序,直到间距为1时停止,这个过程中数列逐渐趋于有序,操作次数也比直接插入操作少。

    动图演示:
    请添加图片描述
    参考:菜鸟教程

    算法步骤:

    • 选择一个序列 stride1、stride2、… 、1,其中后一个元素比前一个小。
    • 序列个数 k,对序列进行 k 趟排序;
    • 每趟排序,根据对应的间距,将待排序列分割成若干子序列,分别对各子表进行直接插入排序。

    c++实现:

    template<typename T>
    void shell_sort(T* array, int length) {
        int h = 1;
        while (h < length / 3) {
            h = 3 * h + 1;
        }
        while (h >= 1) {
            for (int i = h; i < length; i++) {
                for (int j = i; j >= h && array[j] < array[j - h]; j -= h) {
                    std::swap(array[j], array[j - h]);
                }
            }
            h = h / 3;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
  • 相关阅读:
    三、C#—变量,表达式,运算符(3)
    <位图(bitset)和布隆过滤器(BloomFilter)>——《C++高阶》
    YOLOv6-4.0部分代码阅读笔记-voc2yolo.py
    linux系统中日志简介
    基于python实现MQTT 开发以及使用 已解决
    基于pytorch使用特征图输出进行特征图可视化
    罗技鼠标驱动怎么设置宏?
    帮微软语音助手纠正“阿弥陀佛”“e”字错误发音的技巧
    游戏厅ps5体验馆计时收费软件 佳易王电玩馆计时器定时语音提醒系统操作教程
    word中使用latex多行公式,矩阵公式
  • 原文地址:https://blog.csdn.net/weixin_45773137/article/details/126197889
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号