当前位置: 首页 > article >正文

蓝桥杯每日一题2023.11.20

题目描述

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

题目分析

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

#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 - 环的个数则为需要交换的个数。

#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;
}

http://www.kler.cn/news/135628.html

相关文章:

  • WPF Visual, UIElement, FrameworkElement, Control这些类的区别
  • 【论文阅读】基于隐蔽带宽的汽车控制网络鲁棒认证(二)
  • 力扣刷题-二叉树-二叉树最小深度
  • 【STM32】RTC(实时时钟)
  • 13.真刀实枪做项目---博客系统(页面设计)
  • PHPmail 发送邮件错误 550 的原因是什么?
  • qt笔记之qml和C++的交互系列(一):初记
  • 8、创建第一个鸿蒙页面并实现页面跳转
  • nrm的安装以及使用
  • Django+Vue项目创建 跑通
  • 小迪安全笔记——Web架构篇语言中间件数据库系统源码获取
  • 【十字链表,邻接多重表(无向图的另一种链式存储结构),图的遍历】
  • 代码随想录算法训练营第13天|● 239. 滑动窗口最大值 ● 347.前 K 个高频元素 ● 总结
  • 三种爱心代码html(文本文档即可实现)
  • 又欲又撩人,基于新版Bert-vits2V2.0.2音色模型雷电将军八重神子一键推理整合包分享
  • 企业级SSD还是一个巨大的蓝海~
  • NAS层协议栈学习笔记
  • Redis非关系型数据库
  • Elasticsearch同义词最佳实践
  • 软件测试入门很容易,但想要深造就还是要费功夫
  • Python 自动化(十八)admin后台管理
  • C++学习 --pair
  • AIGC 技术在淘淘秀场景的探索与实践
  • JUnit 单元自动化
  • 计算机毕业设计 基于SpringBoot的企业内部网络管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解
  • 五、hdfs常见权限问题
  • 二次开发库Demo【C#】
  • YOLOv8 加持 MobileNetv3,目标检测新篇章
  • 微信浏览器自动播放音频(兼容Android和iOS)
  • BP神经网络原理与如何实现BP神经网络