✅作者简介:C/C++领域新星创作者,为C++和java奋斗中
✨个人社区:微凉秋意社区
🔥系列专栏:经典算法
📃推荐一款模拟面试、刷题神器👉注册免费刷题
🔥前言
今天给大家带来直接插入排序这一经典算法的概念、实现以及效率分析,并使用具体题目来巩固练习。基础算法都不会难的,但是并不代表不重要,在思考的过程中可以锻炼自己思维能力。
挑战赛活动地址: CSDN21天学习挑战赛
每次从原有数据中取出一个数,插入到之前已经排好的序列中,直到所有的数全部取完,那么新的有序排列也就完成了。
首先他是一个排序算法,因此最终结果一定是一组有序的元素(一般为升序排列),那么就可以类比为扑克中我们手牌的顺序。当我们有牌的情况下摸牌,是不是会习惯性的将新摸到的牌与老牌做一个排序,那么这种用新牌与老牌比较并插入到手牌的方法与直接插入排序方法思想别无二致。

#include
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);
}

- 利用随机数给数组
arr赋值,对应的函数为randArr- 直接插入排序函数
dirInsert,这个也是本文的核心内容,用来做元素排序- 查看元素函数
showInfo查看排序前后的元素情况
讨论最好和最坏的情况:
while循环中又执行了n-1次,非常接近n的平方,因此时间复杂度为O(
n
2
n^{2}
n2)写在最后
快来一起打下算法基础,共同成长进步吧!!!