【学习总结】插入排序

本文介绍了插入排序的基本思想和实现过程。通过外部循环扫描序列并进行内部循环找到合适位置插入元素,达到排序目的。在有序序列情况下最优,时间复杂度为o(N),而在逆序情况下最坏,时间复杂度为o(N^2)。插入排序的空间复杂度为o(1)。
摘要由CSDN通过智能技术生成

前言

插入排序,一般也被称为直接插入排序。对于少量元素的排序,它是一个有效的算法。

1.1 算法思想

每一次将一个待排序的元素,按其关键字大小插入到有序队列的合适位置,直到全部元素插入完成为止。

图片来源于网络
假设有一组无序序列 R0, R1, … , Rn-1

  1. 将序列中下标为 0 的元素视为元素个数为 1 的有序序列。
  2. 依次把 R1, R2, … , Rn-1 插入到有序序列中。所以,需要一个从下标 1N-1的外部循环去扫描 。
  3. 插入过程,将 Ri 插入到前面有序的序列中, RiR0 ~ 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.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值