码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构之折半插入排序


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

     作者简介:大家好我是小唐同学(๑>؂<๑),为梦想而奋斗的小唐,让我们一起加油!!!

    个人主页:小唐同学(๑>؂<๑)的博客主页

    系列专栏:数据结构

    博友们如果也是新手入门数据结构我希望大家可以多加练习 数据结构题库在牛客网就有已经给大家附上链接,可以直接点击跳转:刷题点这里

    牛客网支持ACM模式哦,刷算法题也很推荐哦!!!

    下面上文章------》

     

    目录

     

    刷题推荐:​

    折半插入排序概念:

    算法步骤:

    输入:

    输出:

    算法思想:

    算法图示:

    算法比较过程:

    算法实现:

    时间复杂度:

    空间复杂度:


    刷题推荐:

    折半插入排序概念:

    折半插入排序是直接插入排序与折半查找的结合,由于在插入排序过程中,已经生成一个(排好的元素组成的)有序数列。所以在插入代排元素时可以使用折半查找的方式来确定新元素的位置,当元素个数较多时,折半插入排序是优于 直接插入排序的。

    算法步骤:

    输入:

    n个数的序列(数组--乱序)

    输出:

    输出一个排列好的新序列(默认升序)

    算法思想:

    折半插入排序时对一个序列分为有序区和无序区,有序区初始状态为0,直到无序区为0结束

    折半插入排序思想其实与直接插入排序极其相似,只是查找的方式不同,

    直接插入排序:从后向前依次比较寻找位置

    折半插入排序:利用已排好数列进行折半查找进行确定位置

    算法图示:

             

    算法比较过程:

    1. 输入数据序列被分为有序区和无序区俩部分

    2.最初有序区是没有元素的,从无序区不断取出元素(有序)放入

    3.已知前i个元素已经有序排列,则第i+1个元素(无序区第一个---后文称为目标元素)

    4.先与有序区的最后一个元素比较

            (1)如果目标值较大则说明此时位置正确,直接归入有序区,进行下一位判断

            (2)如果目标值较小则说明目标值在前列,需要进行二分查找判断位置

                    ①搜索区间变为原来的一半,折半查找若有问题请看上文:数据结构与算法之折半查找

                    ②确定位置后,将有序区间从后往前逐个后串,最后将临时变量temp中的值覆盖插入的位置

    算法实现:

    1. # include
    2. using namespace std;
    3. int main()
    4. {
    5. int a[7];
    6. for(int i=0;i<7;i++)
    7. {
    8. cin>>a[i];
    9. }
    10. for(int i=1;i<7;i++)//i为无序区的首号元素
    11. { int temp=a[i];
    12. if(a[i]-1])//当 a[i]>a[i-1]时自动i++
    13. {
    14. int left=0;
    15. int right=i-1;
    16. while(left<=right)
    17. {
    18. int mid=(left+right)/2;
    19. if(a[mid]<=temp)
    20. {
    21. left=mid+1;
    22. }
    23. else
    24. right=mid-1;
    25. }
    26. for(int j=i-1;j>=right;j--)
    27. {
    28. a[j+1]=a[j];
    29. }
    30. a[right+1]=temp;
    31. }
    32. }
    33. for(int i=0;i<7;i++)
    34. {
    35. cout<" ";
    36. }
    37. }

    时间复杂度:

    最好的情况:O(n)--遍历一遍

    最坏的情况:O(n*n)--每一个都要调换位置

    综上则平均时间复杂度为O(n*n);

    空间复杂度:

    中间用到中间变量,但是为常数,则空间复杂度为:O(1)

  • 相关阅读:
    面了三十个人,说说我的真实感受
    文献 | 柳叶刀发文:虚拟现实的新用途之治疗场所恐惧症
    【苍穹外卖 | 项目日记】第四天
    【前端】Vue实现个人空间
    【Linux】Linux的常见指令详解(上)
    【 OpenGauss源码学习 —— 列存储(analyze)(四)】
    保障人脸安全!顶象发布《人脸识别安全白皮书》
    DDoS高防IP到底是什么?
    Spring Bean的作用域有哪些?它的注册方式有几种?
    k8s1.18.0完整部署教程
  • 原文地址:https://blog.csdn.net/m0_61469860/article/details/126311196
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号