NC20566 [SCOI2010]游戏
题目
题目描述
lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示。当他使用某种装备时,他只能使用该装备的某一个属性。并且每种装备最多只能使用一次。
游戏进行到最后,lxhgww遇到了终极boss,这个终极boss很奇怪,攻击他的装备所使用的属性值必须从1开始连续递增地攻击,才能对boss产生伤害。也就是说一开始的时候,lxhgww只能使用某个属性值为1的装备攻击boss,然后只能使用某个属性值为2的装备攻击boss,然后只能使用某个属性值为3的装备攻击boss……以此类推。现在lxhgww想知道他最多能连续攻击boss多少次?
输入描述
输入的第一行是一个整数N,表示lxhgww拥有N种装备
接下来N行,是对这N种装备的描述,每行2个数字,表示第i种装备的2个属性值
输出描述
输出一行,包括1个数字,表示lxhgww最多能连续攻击的次数。
示例1
输入
3
1 2
3 2
4 5
输出
2
备注
对于 \(30\%\) 的数据,保证 \(N \leq 1000\)
对于 \(100\%\) 的数据,保证 \(N \leq 1000000\)
题解
方法一
知识点:图论,DFS。
把装备的两个属性值抽象成一条边的两个点,每条边只能选择一个点,那么对于一个连通图有大于等于点数量的边,那么这个连通图是存在环的,那就一定有方法使得所有点都选到,否则最大值不能选到。
于是,建图后枚举所有点的连通情况,如果存在环就是所有都能取到,如果不存在环则最大值取不到,将第一个不能取到的值设为最大值,如此遍历所有数字即可得到确定的第一个不能取到的数字,答案就是这个数字减一。
时间复杂度 \(O(n)\)
空间复杂度 \(O(n)\)
方法二
知识点:并查集。
原理和方法一一样,将存在关系的点放入一个集合,根节点权值设为这个集合的最大值,如果存在两个点在一个集合后又被合并一次说明这个集合的点存在环,否则没有。
遍历所有集合找到不能取到最大值的集合中的最小值,减一即是答案。
时间复杂度 \(O(n)\)
空间复杂度 \(O(1)\)
方法三
知识点:贪心。
对于每个装备取较小属性值,如果这个值已经取过了那就取较大的属性值,将访问信息存入一个数组,如此得到一个最小能取到的属性值的数组,遍历数组直到第一个不能去到的数为止,减一即是答案。
时间复杂度 \(O(n)\)
空间复杂度 \(O(1)\)
代码
方法一
#include <bits/stdc++.h>
using namespace std;
vector<int> g[10007];
bool vis[10007];
int maxn;
bool dfs(int u, int fa) {
bool flag = false;///判断环
for (int i = 0;i < g[u].size();i++) {
int v = g[u][i];
if (fa == v) continue; ///和其他标记不一样,父节点单独考虑
if (vis[v]) { flag = true; continue; }///有环还不能跳出,要找到最大值
vis[v] = 1;///标记
maxn = max(maxn, v);///更新连通块最大值
if (dfs(v, u)) flag = true;///传递环信息
}
return flag;
}
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int n;
cin >> n;
int ans = 0;
for (int i = 0;i < n;i++) {
int u, v;
cin >> u >> v;
g[u].push_back(v);
g[v].push_back(u);
ans = max({ ans,u,v });
}
ans++;///表示不能到达的第一个数
for (int i = 1;i <= ans - 1;i++) {
if (!vis[i]) {
vis[i] = 1;
maxn = i;
if (!dfs(i, 0)) ans = min(ans, maxn);
}
///如果没访问,且所在连通块无环,则仅最大数一定不可达,更新为ans
///其他数如果之前的数都可达,则一定可达,因此访问过的不需要再次访问
}
cout << ans - 1 << '\n';///遍历区间后能确定ans
return 0;
}
方法二
#include <bits/stdc++.h>
using namespace std;
int fa[10007];
int maxn[10007];///维护连通块最大值
bool flag[10007];///维护环信息
int find(int x) {
return fa[x] == x ? x : fa[x] = find(fa[x]);
}
void merge(int u, int v) {
int ru = find(u);
int rv = find(v);
if (ru == rv) flag[ru] = 1;
else {
fa[ru] = rv;
maxn[rv] = max(maxn[ru], maxn[rv]);
flag[rv] |= flag[ru];
}
}
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
for (int i = 1;i <= 10000;i++) fa[i] = i, maxn[i] = i;
int n;
cin >> n;
int ans = 0;
for (int i = 0;i < n;i++) {
int u, v;
cin >> u >> v;
merge(u, v);
ans = max({ ans,u,v });
}
ans++;
for (int i = 1;i <= ans - 1;i++) {
if (fa[i] == i && !flag[i]) ans = min(ans, maxn[i]);
}
cout << ans - 1 << '\n';
return 0;
}
方法三
#include <bits/stdc++.h>
using namespace std;
bool vis[10007];
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int n;
cin >> n;
for (int i = 0;i < n;i++) {
int u, v;
cin >> u >> v;
if (!vis[min(u, v)]) vis[min(u, v)] = 1;
else vis[max(u, v)] = 1;
}
int ans = 1;
while (vis[ans]) {
ans++;
}
cout << ans - 1 << '\n';
return 0;
}
NC20566 [SCOI2010]游戏的更多相关文章
- BZOJ 1854: [Scoi2010]游戏 无向图判环
题目链接: 题目 1854: [Scoi2010]游戏 Time Limit: 5 Sec Memory Limit: 162 MB 问题描述 lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装 ...
- BZOJ 1854: [Scoi2010]游戏( 二分图最大匹配 )
匈牙利算法..从1~10000依次找增广路, 找不到就停止, 输出答案. --------------------------------------------------------------- ...
- 1854: [Scoi2010]游戏
1854: [Scoi2010]游戏 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 2538 Solved: 905[Submit][Status] ...
- 【BZOJ】1854: [Scoi2010]游戏【二分图】
1854: [Scoi2010]游戏 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 6759 Solved: 2812[Submit][Status] ...
- BZOJ 1854: [Scoi2010]游戏 并查集
1854: [Scoi2010]游戏 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 2672 Solved: 958[Submit][Status][ ...
- 【BZOJ1854】[Scoi2010]游戏 二分图最大匹配
[BZOJ1854][Scoi2010]游戏 Description lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当 ...
- bzoj1854 [Scoi2010]游戏 ([SCOI2010]连续攻击游戏)
bzoj1854 [Scoi2010]游戏 ([SCOI2010]连续攻击游戏) 据说正解是并查集???我不会 这不是一道匈♂牙利好题吗??? 一个装备的两个属性都向它连边,然后跑一遍匈♂牙利 注意: ...
- 1854: [Scoi2010]游戏[并查集]
1854: [Scoi2010]游戏 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 4938 Solved: 1948[Submit][Status] ...
- [BZOJ1854][SCOI2010]游戏 二分图最大匹
1854: [Scoi2010]游戏 Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 5316 Solved: 2128[Submit][Status] ...
随机推荐
- Unreal 输入系统 解析
前言 输入系统,输入某个键,响应到GamePlay层做对应的事.例如 点击鼠标,前进还是开枪之类,是如何响应的.这里只说应用层逻辑,硬件层逻辑不讲述. 详解 1.问题来源 先看下面一个例子:跳跃的事件 ...
- CSS躬行记(11)——管理后台响应式改造
为了提升业务人员操作管理后台的体验,花了点时间进行响应式的改造,紧急情况时,掏出手机就能工作. 利用CSS3的媒体查询,就能根据不同屏幕的尺寸采用不同的样式来渲染,目前使用的移动端屏幕阈值为750px ...
- 从旧金山到上海, HTTP/3 非常快!
HTTP/3 是超文本传输协议 (HTTP) 的第三个版本,它对 Web 性能来说意义重大, 让我们看看HTTP/3 如何让网站的速度变得更快! 等等,HTTP/2 发生了什么? 不是几年前才开始推广 ...
- UNIAPP实现PDA扫码
目前我接触到了两种方法,以扫码pda安卓采集器(可以直接理解为手机上有个激光扫码)的设置划分. 1.扫描设置 --> 键盘方式输出(键盘类型:物理键盘),注意设置要看具体的型号: 2.扫码设置 ...
- 图文详解 HDFS 的工作机制及其原理
大家好,我是大D. 今天开始给大家分享关于大数据入门技术栈--Hadoop的学习内容. 初识 Hadoop 为了解决大数据中海量数据的存储与计算问题,Hadoop 提供了一套分布式系统基础架构,核心内 ...
- c# 读取所有磁盘的剩余空间
介绍: 有一个控制台命令是创建指定大小的空文件,因此我想制作一个一键填充剩余磁盘空间的坑人小程序. 想要填充剩余容量,就要先获取所有本地磁盘的剩余空间,这个程序就是用来做这个的. 项目类型为c#控制台 ...
- 组织:EFF
电子前沿基金会(Electronic Frontier Foundation), 简称EFF,是一个非营利性的国际法律组织.该组织成立于1990年,创始人包括Mitch Kapor(Lotus公司的总 ...
- find-文件搜索
根据条件搜索文件. 语法 find 目录 [选项] 选项 -name <filename> 按文件目录名查找.文件目录名可使用通配符"*",即表示模糊匹配所有字符. - ...
- mmdetection源码阅读
2021-11-23号更新 mmdetection中的hook函数 参考: 重难点总结: # step1: 根据官方文档,getattr(self,'name')等同于self.name # sept ...
- Windows环境下安装RabbitMQ
本地安装RabbitMQ安装注意事项: Erlang与RabbitMQ,安装路径都应不含空格符. Erlang使用了环境变量HOMEDRIVE与HOMEPATH来访问配置文件.erlang.cooki ...