【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;
    }
}

分析

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

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

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

相关推荐
weixin_458872614 分钟前
东华复试OJ二刷复盘2
算法
Charlie_lll5 分钟前
力扣解题-637. 二叉树的层平均值
算法·leetcode
爱淋雨的男人15 分钟前
自动驾驶感知相关算法
人工智能·算法·自动驾驶
wen__xvn27 分钟前
模拟题刷题3
java·数据结构·算法
滴滴答滴答答39 分钟前
机考刷题之 6 LeetCode 169 多数元素
算法·leetcode·职场和发展
Neteen1 小时前
【数据结构-思维导图】第二章:线性表
数据结构·c++·算法
礼拜天没时间.1 小时前
力扣热题100实战 | 第25期:K个一组翻转链表——从两两交换到K路翻转的进阶之路
java·算法·leetcode·链表·递归·链表反转·k个一组翻转链表
Swift社区2 小时前
LeetCode 400 第 N 位数字
算法·leetcode·职场和发展
再难也得平2 小时前
力扣239. 滑动窗口最大值(Java解法)
算法·leetcode·职场和发展
摩尔曼斯克的海2 小时前
力扣面试题--双指针类
python·算法·leetcode