活动地址:CSDN21天学习挑战赛
✅作者简介:C/C++领域新星创作者,为C++和java奋斗中 ✨个人社区:微凉秋意社区 🔥系列专栏:经典算法 📃推荐一款模拟面试、刷题神器👉注册免费刷题
🔥前言
书接上文,今天带来算法基础中的折半插入排序,一个综合了直接插入排序和二分查找的算法。和以往四篇不同,这篇文章将会加入详细调试的图片,帮助大家理解该算法的流程。本篇文章也将收录在经典算法专栏,此专栏免费且收录经典算法,感兴趣的朋友可订阅以便持续观看。
文章目录
折半插入排序算法解析
一、理解算法思想
- 折半插入排序算法解析
- 一、理解算法思想
- 二、算法流程
- 三、代码实现
- 1、源代码
- 2、运行效果
- 四、调试程序,分析算法流程
- 1、详细的调试过程
- 2、时间复杂度
- 每次从原有数据中取出一个数,插入到之前已经排好的序列中,直到所有的数全部取完,该算法过程与直接插入排序算法极为相似,区别就是在插入的时候 高效 的选择位置。
- 使用二分(折半)查找来选择插入位置
- 外层循环用来找到序列中无序的入口
- 进入无序入口后,记录入口位置元素值并进入二分查找
- 二分查找结束后,将元素值向依次后覆盖
- 最后将入口位置的元素值插入到二分查找结束的位置即可
int main(void)
{
int arr[6] = { 27,45,50,35,66,32 };
int len = sizeof(arr) / sizeof(arr[0]);
cout
关注
打赏
热门博文
- 【Java】设计模式之单例模式与工厂模式
- 【Java面试宝典】线程安全问题|线程死锁的出现|线程安全的集合类
- 【Rust指南】错误的分类与传递|使用kind进行异常处理
- 【Servlet】规范项目结构|基于Mysql+JDBC+Servlet 制作简易网页|实现登录、添加、删除、显示的功能
- 【C语言】规范掌握C语言函数|数组名的妙用|指针快速入门|综合使用小案例
- 【Servlet】超详细开发步骤|在idea上配置Tomcat|网页显示当前系统时间
- 新学期,新FLAG | 要以码为梦而非夜郎自大
- 猿创征文 | 【Rust指南】枚举类与模式匹配精讲
- 牛客网《剑指offer》专栏刷题练习之二叉树合集
- 开学季&河科大社区活动详情介绍实例
