夏令营复习coding 算法第一天-状态:新奇

T1:bubble冒泡排序

(1)思路:两次循环,外层循环从后面开始-作为一个支点,内层循环每次将当前需要排序的最大的那个元素一步步移动到该支点,最终升序排列完成

(2)代码:

复制代码
#include <stdio.h>
#include<iostream>
using namespace std; 

int n;
int a[10001];

void swap(int &a,int &b)
{
	int tmp = a;
	a = b;
	b = tmp;
}

int main(){
	scanf("%d", &n);
	for (int i = 1; i <=n; i++) scanf("%d", &a[i]);

	//已经输入的数据全部存储到了a[1-n]当中,利用bubble_sort进行排序
	for(int i = n-1;i>=1;i--)
	{
		for(int j = 1; j<=i; j++)
		{
			if(a[j] > a[j+1])
			{
				swap(a[j],a[j+1]);
			}
		}
	 } 

	for (int i = 1; i <= n; i++) printf("%d ", a[i]);
	return 0;
}
T2: 插入排序:

(1)思路:i从2到n,每次找到 a[i] 需要待的 位置 ,然后先后移 再存放

(2)代码:

复制代码
#include<iostream>

int n;
int a[10001];

int main()
{
	scanf("%d", &n);
	for (int i = 1; i <=n; i++) scanf("%d", &a[i]);
	//--以上处理了 元素 a1 - an 存储到 a[1] -- a[n] 中 
	//--对这 n 个元素 进行 插入排序
	
	//初始 第一个 元素 设置 为 a[1]
	//然后 , i从 2-n对 元素 a[i] 进行找到第一个 比它 大的 元素 , 放到 这个元素的 前面
	for(int i=2;i<=n;i++)
	{
		for(int j = 0;j<=i-1;j++)
		{
			if(a[j] >= a[i])
			{
				//a[i] 需要 放到a[j] 这个位置, 然后 j-i-1之间的元素 全部后移一个位置,并且break跳出循环
				int tmp =a[i];
				for(int k = i-1;k>=j;k--)
				{
					a[k+1] = a[k];
				 } 
				 a[j] = tmp;
				 break; // 跳出 这一次的 寻找 
			}
		}
	 } 
	
	//-- 以下 处理 输出 部分 
	for (int i = 1; i <= n; i++) printf("%d ", a[i]);
	return 0;
}
相关推荐
于小猿Sup1 小时前
VMware在Ubuntu22.04驱动Livox Mid360s
linux·c++·嵌入式硬件·自动驾驶
x_yeyue2 小时前
三角形数
笔记·算法·数论·组合数学
Mr. zhihao3 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
念何架构之路3 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星3 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
小小编程路3 小时前
C++ 多线程与并发
java·jvm·c++
失去的青春---夕阳下的奔跑3 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光4 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩4 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_629494734 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表