蓝桥杯 插入排序

插入排序的思想

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

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

列。

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

时间复杂度为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; 
}
相关推荐
西安同步高经理11 分钟前
秒表实现自动化测量助力时频测量行业发展、秒表检定仪、毫秒表测量仪
人工智能·算法
夏幻灵16 分钟前
C++ 里 什么时候不用指针,而选择值拷贝/深拷贝 ?
开发语言·c++·算法
这猪好帅18 分钟前
【算法】动态规划 - 数字三角形模型
算法·动态规划
yong999021 分钟前
基于小波分析与粒子群算法的电网潮流优化实现(MATLAB)
开发语言·算法·matlab
superman超哥22 分钟前
仓颉语言中字典的增删改查:深度剖析与工程实践
c语言·开发语言·c++·python·仓颉
Christo326 分钟前
2024《Three-way clustering: Foundations, survey and challenges》
人工智能·算法·机器学习·数据挖掘
青山是哪个青山27 分钟前
第一节:CMake 简介
linux·c++·cmake
艾醒34 分钟前
大模型原理剖析——解耦RoPE(旋转位置编码)的基本原理
算法
@淡 定37 分钟前
JVM内存区域划分详解
java·jvm·算法
疑惑的杰瑞42 分钟前
【C】常见概念
c语言·编译原理