YYHS-NOIP2017Training0928-ZCC loves Isaac
题目描述
【背景】
ZCC又在打Isaac。这次他打通了宝箱关进入了表箱关。
【题目描述】
表箱关有一个房间非常可怕,它由n个变异天启组成。
每个天启都会在进入房间后吐出绿弹并炸向某一个位置且范围内只有一个天启。若该位置的天启已经死亡则没有事情发生,否则该位置的天启会死亡。每个天启只能且必须吐一次绿弹(除非在它吐弹以前他就挂了)。
绿弹的飞行速度很快,在某个绿弹落地之前不会有新的绿弹被吐出。
虽然房间的天启位置和吐弹位置固定,但是吐弹顺序是随机的,所以ZCC不能很好地制定策略。
现在ZCC想知道,最少和最多有几个天启被干掉。
输入
第一行n表示天启个数。
第二行n个数ai表示i号天启的目标是ai。
注意:行末有一个空格。
输出
一行两个数表示最少和最多有几个天启被干掉。
样例输入
2 3 2 2 6 7 8 5
样例输出
提示
【样例解释】

|
测试点编号
|
n的范围
|
其他
|
测试点编号
|
n的范围
|
其他
|
|
1
|
=10
|
随机生成
|
6
|
=10000
|
处于一个联通块
|
|
2
|
=100
|
随机生成
|
7
|
=100000
|
所有天启都能被炸到
|
|
3
|
=1000
|
随机生成
|
8
|
=100000
|
无
|
|
4
|
=1000
|
随机生成
|
9
|
=1000000
|
处于一个联通块
|
|
5
|
=10000
|
随机生成
|
10
|
=1000000
|
无
|
题解
这道题刚开始弄了我很久,后来发现每个点只会向后连一条边,这样就少了很多种特殊情况
这道题要我们求最少和最多被干掉的天启数量
我们把图的情况想象成 单独一个环和其他的情况
求最少的数量
我们对于单独的环最少一定是干掉 (环的长度+1)/2 个天启
而对于其他的情况 我们就从入度为0的点开始往后找,把这些点标记掉,再找入度为0的点,这样继续,在判断的时候把干掉的加起来即可
求最大的数量
单独的环最后一定是只剩下一个(自环除外),自环就要特判一下
其他情况就只有入度为0的点存活,其他都会被干掉
怎么求单独的环呢?这个问题确实弄了我很久
其实我们可以先把入度为0的点向后找,边找边标记,一直找到找不了为止,这样剩下来的点就是构成环的点了
#include<bits/stdc++.h>
#define N 1000005
using namespace std;
int n,cnt,Max,Min,k,u,v;
int a[N],in[N],s[N],flag[N];
int calc(int u){
flag[u]=;
int sum=,v=u;
while (!flag[a[v]]){
flag[a[v]]=;
sum++;
v=a[v];
}
if (sum==) sum=;
return sum;
}
int main(){
scanf("%d",&n);
for (int i=;i<=n;i++){
scanf("%d",&a[i]);
in[a[i]]++;
}
for (int i=;i<=n;i++)
if (!in[i]) s[++cnt]=i,flag[i]=true;
int num=;
while (num<=cnt){
k=s[num];
u=a[k];
if (!flag[u]){
Min++; flag[u]=true;
v=a[u];
in[v]--;
if (!in[v]){
s[++cnt]=v;
flag[v]=true;
}
}
num++;
}
for (int i=;i<=n;i++)
if (!flag[i]) Min+=(calc(i)+)/;
memset(flag,,sizeof(flag));
for (int i=;i<=n;i++)
in[a[i]]++;
cnt=;
for (int i=;i<=n;i++)
if (!in[i]) s[++cnt]=i,flag[i]=true;
num=;
while (num<=cnt){
k=s[num];
u=a[k];
if (!flag[u]){
Max++; flag[u]=true;
s[++cnt]=u;
}
num++;
}
for (int i=;i<=n;i++)
if (!flag[i]) Max+=calc(i)-;
printf("%d %d\n",Min,Max);
return ;
}
YYHS-NOIP2017Training0928-ZCC loves Isaac的更多相关文章
- 3828. 三角形计数 3829. ZCC loves Isaac 3830. 字符消除
3828 给定n个点的坐标(0<=xi,yi<=10000)求选出任意三个点能组成的三角形的总面积. 题解 太naive了 枚举三角形的y最小的点,把剩余的点按角度排序 然后随便算,可以用 ...
- 2014---多校训练2(ZCC Loves Codefires)
ZCC Loves Codefires Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- HDU 4876 ZCC loves cards(暴力剪枝)
HDU 4876 ZCC loves cards 题目链接 题意:给定一些卡片,每一个卡片上有数字,如今选k个卡片,绕成一个环,每次能够再这个环上连续选1 - k张卡片,得到他们的异或和的数,给定一个 ...
- HDU-4882 ZCC Loves Codefires
http://acm.hdu.edu.cn/showproblem.php?pid=4882 ZCC Loves Codefires Time Limit: 2000/1000 MS (Java/Ot ...
- HDU 4882 ZCC Loves Codefires (贪心)
ZCC Loves Codefires 题目链接: http://acm.hust.edu.cn/vjudge/contest/121349#problem/B Description Though ...
- hdu 4873 ZCC Loves Intersection(大数+概率)
pid=4873" target="_blank" style="">题目链接:hdu 4873 ZCC Loves Intersection ...
- HDU 4882 ZCC Loves Codefires(贪心)
ZCC Loves Codefires Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/O ...
- hdu 4882 ZCC Loves Codefires(数学题+贪心)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4882 ------------------------------------------------ ...
- hdu 4876 ZCC loves cards(暴力)
题目链接:hdu 4876 ZCC loves cards 题目大意:给出n,k,l,表示有n张牌,每张牌有值.选取当中k张排列成圈,然后在该圈上进行游戏,每次选取m(1≤m≤k)张连续的牌,取牌上值 ...
- 多校训练赛2 ZCC loves cards
ZCC loves cards Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
随机推荐
- “无文件”恶意软件的威力:悄无声息一夜之间从ATM机中窃取80万美元
去年雅虎接连曝出多个超大规模数据泄露事件,长期关注的你们一定都知道,5亿.10亿账户信息泄露的,除了雅虎也没谁了.就在这两天,5亿账户泄露的真相似乎正在浮出水面. 事件回顾 我们今天要讲的就是这桩5亿 ...
- python汉字输出编码问题
python中文输出乱码问题困扰了多少初学者,我在这方面栽了不知道多少跟头.现在我把我碰到的问题和解决的方法写出来与大家分享一下: 1输出乱码 所谓的乱码是指“鎴戞槸涓枃瀛楃涓”这样的内容.为什么 ...
- 一个还算简单的微信消息SDK(基于.Net Standard 2.0)
虽然微信公众号出现了好久,不过在SDK这件事情上感觉并没有多少人把它当成一个有技术含量的事情来做,很多SDK做的事情就是一个代码的堆叠,当然也可能写的好的并没有开源出来.所以在某个翻遍Github而无 ...
- web站点优化之使用tengine搭建静态资源服务器,静态资源合并加载案例剖析
在一个项目还是单体架构的时候,所有的js,css,image都会在一个web网站上,看起来并没有什么问题,比如下面这样: 但是当web网站流量起来的时候,这个单体架构必须要进行横向扩展,而在原来的架构 ...
- Eclipse关闭项目
Eclipse 关闭项目 为什么要关闭项目? Eclipse 工作空间包含了多个项目.一个项目可以是关闭或开启状态. 项目打开过多影响有: 消耗内存 占用编译时间:在删除项目.class 文件(Cle ...
- Electron 实战桌面计算器应用
前言 Electron 是一个搭建跨平台桌面应用的框架,仅仅使用 JavaScript.HTML 以及 CSS,即可快速而容易地搭建一个原生应用.这对于想要涉及其他领域的开发者来说是一个非常大的福利. ...
- QT creator编程C++第一步,说“Hello world!”
这个学期选了计算机学院的<数字图像处理>,正好和我的图像识别项目有所关联,老师说不能用MATLAB来做,这让我一个没学过C++的孩纸欲哭无泪. 只好求助计算机学院的大佬,自学C++. 大佬 ...
- lucene&solr-day1
全文检索课程 Lucene&Solr(1) 1. 计划 第一天:Lucene的基础知识 1.案例分析:什么是全文检索,如何实现全文检索 2.Lucene实现全文检索的流程 a) ...
- 四,ESP8266 TCP服务器
我要赶时间赶紧写完所有的内容....朋友的东西答应的还没做完呢!!!!!!!没想到又来了新的事情,,....... 配置模块作为TCP服务器然后呢咱们连接服务器发指令控制继电器吸合和断开 控制的指令呢 ...
- 关于hashmap的理解
首先分析第一个比较重要的方法 put 方法,源码如下 public V put(K key, V value) { if (key == null) return putForNullKey(valu ...