博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[CF1029E] Tree with Small Distances
阅读量:5049 次
发布时间:2019-06-12

本文共 1519 字,大约阅读时间需要 5 分钟。

树上贪心。

先预处理出距离。我就用dijkstra皮一下QAQ

显然每个距离大于2的点都需要考虑。

我们贪心处理,优先处理距离最大的。

每次连接距离最大的点的父节点和一号节点。

然后打标记就行了。

1 #include
2 #include
3 #include
4 #include
5 using namespace std; 6 7 int n,ans; 8 int hd[200005],to[400005],nx[400005],ec; 9 int dis[200005],f[200005];10 bool v[200005];11 12 void edge(int af,int at)13 {14 to[++ec]=at;15 nx[ec]=hd[af];16 hd[af]=ec;17 }18 19 struct data20 {21 int p,d;22 friend bool operator < (data q,data w)23 {24 return q.d>w.d;25 }26 };27 28 priority_queue
qq;29 30 void dijkstra()31 {32 memset(dis,0x3f,sizeof(dis));33 dis[1]=0;34 qq.push((data){
1,0});35 while(!qq.empty())36 {37 data nw=qq.top();38 qq.pop();39 if(v[nw.p])continue;40 v[nw.p]=1;41 for(int i=hd[nw.p];i;i=nx[i])42 {43 if((!v[to[i]])&&dis[to[i]]>nw.d+1)44 {45 dis[to[i]]=nw.d+1;46 f[to[i]]=nw.p;47 qq.push((data){to[i],dis[to[i]]});48 }49 }50 }51 }52 53 int main()54 {55 scanf("%d",&n);56 for(int i=1;i
2)qq.push((data){i,-dis[i]});68 else v[i]=1;69 }70 while(!qq.empty())71 {72 data nw=qq.top();73 qq.pop();74 if(v[nw.p])continue;75 int fa=f[nw.p];76 v[fa]=1;77 ans++;78 for(int i=hd[fa];i;i=nx[i])79 {80 v[to[i]]=1;81 }82 }83 printf("%d",ans);84 return 0;85 }

 

转载于:https://www.cnblogs.com/eternhope/p/9847836.html

你可能感兴趣的文章
linux字符集修改
查看>>
phpcms 添加自定义表单 留言
查看>>
mysql 优化
查看>>
读书笔记 ~ Nmap渗透测试指南
查看>>
WCF 配置文件
查看>>
动态调用WCF服务
查看>>
oracle导出/导入 expdp/impdp
查看>>
类指针
查看>>
css修改滚动条样式
查看>>
2018.11.15 Nginx服务器的使用
查看>>
Kinect人机交互开发实践
查看>>
百度编辑器UEditor ASP.NET示例Demo 分类: ASP.NET...
查看>>
JAVA 技术类分享(二)
查看>>
android客户端向服务器发送请求中文乱码的问
查看>>
Symfony翻译教程已开课
查看>>
TensorFlow2.0矩阵与向量的加减乘
查看>>
NOIP 2010题解
查看>>
javascript中的each遍历
查看>>
String中各方法多数情况下返回新的String对象
查看>>
浅谈tcp粘包问题
查看>>