[蓝桥杯 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;
}