✅作者简介:人工智能专业本科在读,喜欢计算机与编程,写博客记录自己的学习历程。
🍎个人主页:小嗷犬的个人主页
🍊个人网站:小嗷犬的技术小站
🥭个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。
题目描述
有 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 题。
Python 题解
数据规模较小,直接遍历,不断将遇到的错位瓶子与正确的瓶子交换,记录交换的次数。
n = int(input())
a = list(map(int, input().split()))
ans = 0
for i in range(n):
if i+1 != a[i]:
for j in range(i+1, n):
if a[j] == i+1:
a[i], a[j] = a[j], a[i]
ans += 1
break
print(ans)