【学习挑战赛】经典算法之直接插入排序

简介: 【学习挑战赛】经典算法之直接插入排序

直接插入排序算法解析

一、理解直接插入排序思想

1、算法思想

每次从原有数据中取出一个数,插入到之前已经排好的序列中,直到所有的数全部取完,那么新的有序排列也就完成了。


2、和扑克牌类比

首先他是一个排序算法,因此最终结果一定是一组有序的元素(一般为升序排列),那么就可以类比为扑克中我们手牌的顺序。当我们有牌的情况下摸牌,是不是会习惯性的将新摸到的牌与老牌做一个排序,那么这种用新牌与老牌比较并插入到手牌的方法与直接插入排序方法思想别无二致。


二、算法分析

1、算法流程

c63c42d201d2468680dcfefdba91e621.gif


2、实现步骤

1.从第二个元素开始与第一个元素的大小进行比较:如果比他大,不进行操作,如果比他小,进行交换操作。

2.第二个元素之后的元素挨个与前面的元素值比较且该元素被单独变量记录,如果该元素比前面相邻元素小,直接用相邻元素覆盖此元素下标对应的值,此时该元素的下标往前移动。

3.当前面元素值都小于该值,将此值插入即可。

三、代码实现

1、源码及运行效果

#include<iostream>
using namespace std;
//直接插入排序
void dirInsert(int *arr,int len)
{
  for (int i = 1; i < len; i++) 
  {
    int key = arr[i]; //key是待比较的元素值
    int temp = i - 1; //temp是相邻的元素下标
    while (temp >= 0 && arr[temp] > key)
    {
      arr[temp+1] = arr[temp];
      temp--;
    }
    arr[++temp] = key;
  }
}
//给数组arr赋随机值
void randArr(int* arr, int len)
{
  srand((unsigned int)time(NULL));//随机数种子
  for (int i = 0; i < len; i++) {
    int value = rand() % 100 + 1;
    arr[i] = value;
  }
}
//查看当前数组元素
void showInfo(int *arr,int len)
{
  for (int i = 0; i < len; i++) {
    cout << arr[i] << " ";
  }
  cout << endl;
}
int main(void)
{
  int len = 0;
  cout<<"请输入数组大小:";
  cin >> len;
  int* arr = new int[len];
  randArr(arr,len); //调用randArr给数组arr赋值
  cout << "插入排序前数组元素为:" << endl;
  showInfo(arr, len); //调用showInfo查看数组元素
  dirInsert(arr, len);//调用直接插入排序
  cout << "插入排序后数组元素为:" << endl;
  showInfo(arr, len);
}

f353f1fd4b17435c953567216c06cc29.png

2、代码过程解析

利用随机数给数组arr赋值,对应的函数为randArr

直接插入排序函数dirInsert,这个也是本文的核心内容,用来做元素排序

查看元素函数showInfo查看排序前后的元素情况

3、时间复杂度分析

讨论最好和最坏的情况:


1.最好的情况:

该序列为升序排列,不需要进行元素移动,那么相当于遍历了n次,时间复杂度为O(n)。

2.最坏的情况:

该序列为降序排列,每次都需要移动数据,那么在遍历n次的情况下,while循环中又执行了n-1次,非常接近n的平方,因此时间复杂度为image.png

写在最后


快来一起打下算法基础,共同成长进步吧!!!


目录
相关文章
|
1月前
|
负载均衡 算法
架构学习:7种负载均衡算法策略
四层负载均衡包括数据链路层、网络层和应用层负载均衡。数据链路层通过修改MAC地址转发帧;网络层通过改变IP地址实现数据包转发;应用层有多种策略,如轮循、权重轮循、随机、权重随机、一致性哈希、响应速度和最少连接数均衡,确保请求合理分配到服务器,提升性能与稳定性。
228 11
架构学习:7种负载均衡算法策略
|
3月前
|
存储 算法 安全
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
数据结构与算法系列学习之串的定义和基本操作、串的储存结构、基本操作的实现、朴素模式匹配算法、KMP算法等代码举例及图解说明;【含常见的报错问题及其对应的解决方法】你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
【EMNLP2024】基于多轮课程学习的大语言模型蒸馏算法 TAPIR
阿里云人工智能平台 PAI 与复旦大学王鹏教授团队合作,在自然语言处理顶级会议 EMNLP 2024 上发表论文《Distilling Instruction-following Abilities of Large Language Models with Task-aware Curriculum Planning》。
|
3月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习(8)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
3月前
|
存储 算法 安全
2024重生之回溯数据结构与算法系列学习之顺序表【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
顺序表的定义和基本操作之插入;删除;按值查找;按位查找等具体详解步骤以及举例说明
|
3月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
3月前
|
存储 Web App开发 算法
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
3月前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
3月前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之顺序表习题精讲【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
顺序表的定义和基本操作之插入;删除;按值查找;按位查找习题精讲等具体详解步骤以及举例说明
|
3月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之王道第2.3章节之线性表精题汇总二(5)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
IKU达人之数据结构与算法系列学习×单双链表精题详解、数据结构、C++、排序算法、java 、动态规划 你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!

热门文章

最新文章