前言
插入排序,一般也被称为直接插入排序。对于少量元素的排序,它是一个有效的算法。
1.1 算法思想
每一次将一个待排序的元素,按其关键字大小插入到有序队列的合适位置,直到全部元素插入完成为止。

假设有一组无序序列 R0, R1, … , Rn-1。
- 将序列中下标为 0 的元素视为元素个数为 1 的有序序列。
- 依次把 R1, R2, … , Rn-1 插入到有序序列中。所以,需要一个从下标 1 到 N-1的外部循环去扫描 。
- 插入过程,将 Ri 插入到前面有序的序列中, Ri 和R0 ~ Ri-1 进行比较,确定要插入的合适位置。
做一个内部循环,从后往前比较,即从下标 i-1 开始向 0 进行扫描。
1.2 代码实现
#include <iostream>
#include <vector>
using namespace std;
vector<int> insertSort(vector<int> list){
vector<int> result;
if (list.<

本文介绍了插入排序的基本思想和实现过程。通过外部循环扫描序列并进行内部循环找到合适位置插入元素,达到排序目的。在有序序列情况下最优,时间复杂度为o(N),而在逆序情况下最坏,时间复杂度为o(N^2)。插入排序的空间复杂度为o(1)。
最低0.47元/天 解锁文章
622

被折叠的 条评论
为什么被折叠?



