蓝桥杯 插入排序

插入排序的思想

插入排序是一种简单直观的排序算法,其基本思想是将待排序的元素逐个插入到已排序序列

的合适位置中,使得已排序序列逐渐扩大,从而逐步构建有序序列,最终得到完全有序的序

列。

它类似于我们打扑克牌时的排序方式,将一张张牌插入到已经有序的手牌中。

时间复杂度为O(n^2)。

插入排序的实现

cpp 复制代码
//i表示当前要确定的位置
for(int i=2;i<=n;i++){
	
	//此时[1,i-1]已经为有序的数组
	int val=a[i],j;
	
	//将val和a[j-1]比较
	//如果val<a[j-1]就将a[j-1]往后移动一格
	//给val留出位置
	for(j=i;j>1&&val<a[j-1];j--){
		a[j]=a[j-1];
	} 
	//当循环跳出时,j==1或val>a[j] ,且此时a[j]已经往后移动
	//此时的j为val腾出的位置
	a[j]=val; 
} 

例题讲解

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e3+9;
int a[N];
int main(){
	int n;cin>>n;
	for(int i=1;i<=n;i++)cin>>a[i];
	for(int i=2;i<=n;i++){
	int val=a[i],j;
	for(j=i;j>1&&val<a[j-1];j--){
		a[j]=a[j-1];
	} 
	a[j]=val; 
} 
	for(int i=1;i<=n;i++) cout<<a[i]<<" \n"[i==n];
	return 0; 
}
相关推荐
浪浪小洋9 分钟前
c++ qt课设定制
开发语言·c++
charlie11451419118 分钟前
嵌入式C++工程实践第16篇:第四次重构 —— LED模板,从通用GPIO到专用抽象
c语言·开发语言·c++·驱动开发·嵌入式硬件·重构
handler0123 分钟前
Linux: 基本指令知识点(2)
linux·服务器·c语言·c++·笔记·学习
故事和你9124 分钟前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
我叫黑大帅34 分钟前
为什么map查找时间复杂度是O(1)?
后端·算法·面试
炽烈小老头1 小时前
【每天学习一点算法 2026/04/20】除自身以外数组的乘积
学习·算法
skilllite作者1 小时前
AI agent 的 Assistant Auto LLM Routing 规划的思考
网络·人工智能·算法·rust·openclaw·agentskills
香蕉鼠片2 小时前
MFC是什么
c++·mfc
心态与习惯3 小时前
Julia 初探,及与 C++,Java,Python 的比较
java·c++·python·julia·比较
py有趣3 小时前
力扣热门100题之不同路径
算法·leetcode