【408DS算法题】014基础-直接插入排序

Index

题目

编写函数,实现对顺序表的直接插入排序。


实现代码

cpp 复制代码
#include <vector>
using namespace std;

void insertionSort(vector<int>& a){
	// 排序前认定元素[0]为排序完成
    for (int i = 1; i < a.size(); i++){
        // 区间[0,i-1]已排序完成,定义变量cur记录当前要插入元素
		int cur = a[i];
        int j = i - 1;
		// 不断后移大于cur的元素,为cur腾出位置
        while (j>=0 && a[j]>cur) {
            a[j+1] = a[j];
            j--;
        }
		// 将cur归位
        a[j+1] = cur;
    }
}

分析

插入排序也是一种简单直观的排序算法,具体思想是:在未完成排序元素中选定一个元素,从后向前扫描完成排序元素,找到合适的位置插入。

插入排序的变种包括:直接插入排序、二分插入排序、链表插入排序、希尔排序。

其中最基本的就是直接插入排序,它逐个扫描元素完成插入操作,并能保证算法的稳定性(相等的元素排序前后相对位置不变)。

相关推荐
dog shit21 分钟前
蓝桥杯第十一届省赛C++B组真题解析
算法
Swift社区39 分钟前
LeetCode 252 会议室题全解析:Swift 实现 + 场景还原
算法·leetcode·swift
要下雨了吗40 分钟前
指针数组 vs 数组指针
c语言·数据结构·c++·算法·visual studio
emmmmXxxy1 小时前
leetcode刷题-单调栈
算法·leetcode·职场和发展
MiyamiKK571 小时前
leetcode_数组 189. 轮转数组
python·算法·leetcode·职场和发展
武装头脑ing1 小时前
递增子序列
数据结构·算法
QQ_7781329741 小时前
模运算:数字世界中的时空扭曲法则——从密码学到量子计算的跨维演绎
算法
qq_433554541 小时前
C++ 蓝桥云课代码练习
c++·算法·图论
森焱森2 小时前
单片机FreeRTOSTickless低功耗模式应用示例
c语言·网络·单片机·算法·架构
sml259(劳改版)2 小时前
(PTA) L2-011-L2-015
数据结构·算法