[AGC004D] Teleporter [贪心]
题面:
思路:
分析可知,这道题中的图是一个环套内向树,首都在环上
首先有一个结论:当首都的出边指向首都时,一定最优(不然首都出发可能无法按时到达首都)(可以按时到达的情况也一定有到不了的)
这种情况下首都构成自环,其他边构成一棵指向首都的树
因此可以这样贪心地解决问题:
从所有的叶节点开始拓扑排序,记录每一个节点下属的深度最大的叶节点的深度
如果有一个节点的距离(上述深度)到达了k-1,那么就把这个节点拆下来接到首都上面,剩下的节点继续作为新叶节点拓扑排序
这样所有1的子树的深度都在k以内,到达首都以后可以走自环达到k
Code:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
inline int read(){
int re=,flag=;char ch=getchar();
while(ch>''||ch<''){
if(ch=='-') flag=-;
ch=getchar();
}
while(ch>=''&&ch<='') re=(re<<)+(re<<)+ch-'',ch=getchar();
return re*flag;
}
int n,K,a[],dep[];
int q[],head=,tail=,cnt[];
int main(){
int i,u,ans=;
n=read();K=read();
a[]=read();
if(a[]!=) ans++,a[]=;
for(i=;i<=n;i++) a[i]=read(),cnt[a[i]]++;
// for(i=1;i<=n;i++) cout<<cnt[i]<<ends;cout<<endl;
for(i=;i<=n;i++) if(!cnt[i]) q[tail++]=i;
while(head<tail){
u=q[head++];
// cout<<"topo "<<u<<ends<<dep[u]<<endl;
if(u==) break;
if(a[u]!=&&dep[u]==K-) ans++;
else dep[a[u]]=max(dep[a[u]],dep[u]+);
cnt[a[u]]--;
if(cnt[a[u]]==) q[tail++]=a[u];
}
printf("%d\n",ans);
}
[AGC004D] Teleporter [贪心]的更多相关文章
- [AGC004D] Teleporter(贪心+)
		
Description 维尼管辖的领土很大,我们可以抽象为n个城市,其中1号点为首都.这n个城市之有n条单向电缆,一条信息经过一条电缆进行传输所需时间会+1s,然而维尼并不能忍受时间白白被续,他要求从 ...
 - [agc004D]Teleporter
		
Description 传送门 Solution 依题意我们可以知道,以2-n为出发点的边和1号节点会构成一课树(不然2-n号节点无法都达到首都). 为了让2-n号节点中,离1号节点的距离<k的 ...
 - [agc004d]Teleporter 暴力
		
Description 维尼管辖的领土很大,我们可以抽象为n个城市,其中1号点为首都.这n个城市之有n条单向电缆,一条信息经过一条电缆进行传输所需时间会+1s,然而维尼并不能忍受时间白白被续,他要求从 ...
 - 贪心/构造/DP 杂题选做Ⅲ
		
颓!颓!颓!(bushi 前传: 贪心/构造/DP 杂题选做 贪心/构造/DP 杂题选做Ⅱ 51. CF758E Broken Tree 讲个笑话,这道题是 11.3 模拟赛的 T2,模拟赛里那道题的 ...
 - NOIp模拟赛二十八
		
(这是NOIp模拟赛?应该是NOI模拟赛不小心加了个p) 嗯,假装这是正经的NOIp模拟赛,从今天开始也写写题解吧(这几天被虐的惨惨) 今日情况:8+50+0=58 A题输出样例,B题正解写挂,C题不 ...
 - 【agc004d】Teleporter
		
题目大意 一棵树,改变一些边的父亲,使得深度不超过k. 解题思路 我一开始就想到了贪心,结果莫名其妙的把这种方法给否决了, 然后考虑优化树形dp,然后优化失败⊙﹏⊙ 贪心思路很简单,也很好感受出来,从 ...
 - BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]
		
1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1383 Solved: 582[Submit][St ...
 - HDOJ 1051. Wooden Sticks 贪心 结构体排序
		
Wooden Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
 - HDOJ 1009. Fat Mouse' Trade 贪心 结构体排序
		
FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
 
随机推荐
- python剑指offer 链表中环的入口节点
			
题目: 一个链表中包含环,请找出该链表的环的入口结点. 思路: 先说个定理:两个指针一个fast.一个slow同时从一个链表的头部出发, fast一次走2步,slow一次走一步,如果该链表有环,两个指 ...
 - 【luogu P3609 [USACO17JAN]Hoof, Paper, Scissor蹄子剪刀布】 题解
			
题目链接:https://www.luogu.org/problemnew/show/P3609 ### 看着标签什么记搜什么暴力点进来,读完题第一直觉DP? 还真是个\(DP\). 题目所描述的状态 ...
 - 修改android studio中的avd sdk路径、avd sdk找不到的解决方案
			
要进行Android应用程序的开发,首先就要搭建好Android的开发环境,所需要的工具有如下4个:1.java JDK:2.Android SDK:3.Eclipse:4.ADT 1.java JD ...
 - ZR#317.【18 提高 2】A(计算几何 二分)
			
题意 Sol 非常好的一道题,幸亏这场比赛我没打,不然我估计要死在这个题上qwq 到不是说有多难,关键是细节太多了,我和wcz口胡了一下我的思路,然后他写了一晚上没调出来qwq 解法挺套路的,先提出一 ...
 - linux 下nginx除了首页404的问题
			
今天在部署tp5的时候除了首页能访问.其他都是not found 原因是 Nginx服务器默认不支持pathinfo,index.php后面的参数都没带上 在需要pathinfo支持的程序中 则无 ...
 - iftop工具指令选项记录
			
iftop是实时监控网卡流量的工具,功能十分强大,指令选项非常多,用法比较复杂,下面记录一下命令的选择作用 相关参数及说明 1.iftop界面相关说明 界面上面显示的是类似刻度尺的刻度范围,为显示流量 ...
 - linux正则表达式基础部分
			
1.什么是正则表达式? 简单的说,正则表达式就是为处理大量的字符串而定义的一套规则和方法, 例如:假设“@”代表boy,“!”代表girl.echo“@!” === “boygirl” 通过定义的这些 ...
 - Nginx配置根据客户端设备转发
			
#user nobody; worker_processes ; #error_log logs/error.log; #error_log logs/error.log notice; #error ...
 - JavaScript 字符串分行、Return 语句使用注意事项
			
JavaScript 字符串分行 JavaScript 允许我们在字符串中使用断行语句: var x ="Hello World!"; 但是,在字符串中直接使用回车换行是会报错的: ...
 - 用python给图片添加半透明水印
			
# coding:utf-8 from PIL import Image, ImageDraw, ImageFont def add_text_to_image(image, text): font ...