蓝桥杯每日一题2023.11.20

题目描述

"蓝桥杯"练习系统 (lanqiao.cn)

题目分析

方法一:暴力枚举,如果说数字不在正确的位置上也就意味着这个数必须要改变,进行改变记录即可

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 2e5 + 10;
int n, a[N], ans;
int main()
{
	cin >> n;
	for(int i = 1; i <= n; i ++)cin >> a[i];
	for(int i = 1; i <= n; i ++)
	{
		if(a[i] != i)
		{
			for(int j = i + 1; j <= n; j ++)
			{
				if(a[j] == i)
				{
					swap(a[i], a[j]);
					ans ++;
				}
			}
		}
	}
	cout << ans;
	return 0;
}

方法二:置换群算法,每个数字和对应位置相连可以组成一个环,如果说每个数字可以形成自环也就说明每一个数字都在自己正确的位置上,我们可以找出有几个环,n - 环的个数则为需要交换的个数。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 2e5 + 10;
int a[N], n, cnt;
bool st[N];
int main()
{
	cin >> n;
	for(int i = 1; i <= n; i ++)cin >> a[i];
	for(int i = 1; i <= n; i ++)
	{
		if(!st[i])
		{
			cnt ++;
			for(int j = i; !st[j]; j = a[j])
			{
				st[j] = true;
			}
		}
	}
	cout << n - cnt;
	return 0;
}
相关推荐
Hacker_Oldv7 小时前
数据驱动的测试优化:如何利用数据提高测试效率
自动化测试·软件测试·职场和发展
程序员勋勋8 小时前
高频Robot Framework软件测试面试题
测试工具·职场和发展
软件测试曦曦12 小时前
使用Python接口自动化测试post请求和get请求,获取请求返回值
开发语言·自动化测试·软件测试·python·功能测试·程序人生·职场和发展
kk哥889912 小时前
如何在面试中展现自己的软实力?
面试·职场和发展·cocoa
软件测试雪儿14 小时前
自动化测试面试真题(附答案)
软件测试·测试工具·面试·职场和发展
吃着火锅x唱着歌14 小时前
LeetCode 3185.构成整天的下标对数目II
算法·leetcode·职场和发展
做怪小疯子15 小时前
LeetCode 热题 100——二叉树——二叉树的中序遍历
算法·leetcode·职场和发展
软件测试雪儿15 小时前
2025年100道最新软件测试面试题,常见面试题及答案汇总
软件测试·测试工具·职场和发展
2401_8933266216 小时前
力扣1971.寻找图中是否存在路径
算法·leetcode·职场和发展
软件测试媛16 小时前
软件测试工程师面试题大全(附答案)
功能测试·职场和发展·测试用例