洛谷刷题 | P8637 [蓝桥杯 2016 省 B] 交换瓶子

[蓝桥杯 2016 省 B] 交换瓶子

题目描述

有 N N N 个瓶子,编号 1 ∼ N 1 \sim N 1∼N,放在架子上。

比如有 5 5 5 个瓶子:

2 , 1 , 3 , 5 , 4 2,1,3,5,4 2,1,3,5,4

要求每次拿起 2 2 2 个瓶子,交换它们的位置。

经过若干次后,使得瓶子的序号为:

1 , 2 , 3 , 4 , 5 1,2,3,4,5 1,2,3,4,5

对于这么简单的情况,显然,至少需要交换 2 2 2 次就可以复位。

如果瓶子更多呢?你可以通过编程来解决。

输入格式

第一行:一个正整数 N N N( N < 10000 N<10000 N<10000),表示瓶子的数目。

第二行: N N N 个正整数,用空格分开,表示瓶子目前的排列情况。

输出格式

输出数据为一行一个正整数,表示至少交换多少次,才能完成排序。

样例 #1

样例输入 #1

复制代码
5
3 1 2 5 4

样例输出 #1

复制代码
3

样例 #2

样例输入 #2

复制代码
5
5 4 3 2 1

样例输出 #2

复制代码
2

提示

时限 1 秒, 256M。蓝桥杯 2016 年第七届省赛

蓝桥杯 2016 年省赛 B 组 I 题。

c 复制代码
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<stdbool.h>

#define Pi 3.14
#define MAX 99999

int main(){
	int n;
	int arr[MAX] = {0};
	int i,j;
	scanf("%d",&n);
	for(i=0;i<n;i++){
		scanf("%d",&arr[i]);
	}
	//
	int sum = 0;
	int min,min_num,temp;
	for(i=0;i<n;i++){
		min = arr[i];
		for(j=i+1;j<n;j++){
			if(arr[j]<min){
				min = arr[j];
				min_num = j;
			}
		}
		if(min==arr[i]) continue;
		else{
			temp = arr[min_num];
			arr[min_num] = arr[i];
			arr[i] = temp;
			sum++;
		}
	}
	printf("%d\n",sum);
	
	return 0;
}
相关推荐
非著名架构师6 分钟前
极端天气下的供应链韧性:制造企业如何构建气象风险防御体系
大数据·人工智能·算法·制造·疾风气象大模型·风光功率预测
星轨初途14 分钟前
数据结构排序算法详解(2)——选择排序(附动图)
c语言·数据结构·经验分享·笔记·b树·算法·排序算法
kaikaile19951 小时前
基于 MATLAB 的室内三维定位
算法
AGI前沿2 小时前
AdamW的继任者?AdamHD让LLM训练提速15%,性能提升4.7%,显存再省30%
人工智能·算法·语言模型·aigc
Tan_Ying_Y2 小时前
什么是垃圾回收算法 他的底层原理是什么?
算法
Xの哲學2 小时前
Linux 分区表深度技术剖析
linux·网络·算法·架构·边缘计算
写写闲篇儿2 小时前
经典算法题剖析之传递信息(三)
算法
上不如老下不如小2 小时前
2025年第七届全国高校计算机能力挑战赛初赛 Python组 编程题汇总
开发语言·python·算法
小年糕是糕手2 小时前
【C++】类和对象(二) -- 构造函数、析构函数
java·c语言·开发语言·数据结构·c++·算法·leetcode
kupeThinkPoem3 小时前
跳表有哪些算法?
数据结构·算法