Codeforces Round #216 C Valera and Elections ( DFS )
题目链接: C
题目大意: 给出N(N<=10^5)个结点的树,树上某些路是需要维修的
选择某个结点,从这个结点出发到达1结点的路都会被修复
求这些结点的集合,使得这个集合最小并输出集合的结点(SPJ)
解题思路: 建立无向边,从1结点出发开始DFS,没遍历的点就遍历
回溯的时候记录这段路的第一条需要修复的边顶点加入集合
若该结点的孩子结点已经被加入集合,则不需要再加入集合
代码:
#include#include #include #define MAX 101000struct snode{ int to,w,next;}Tree[MAX<<2];int visit[MAX],pre[MAX],sum[MAX],Index,Answer[MAX],Ansn;void Add_edge(int a,int b,int c){ Tree[Index].w=c;Tree[Index].to=b; Tree[Index].next=pre[a]; pre[a]=Index++;}int DFS(int Star,int w){ visit[Star]=1; //记录结点被访问过 int i,v,pd=0,kk=0; for(i=pre[Star];i!=-1;i=Tree[i].next) { if(visit[Tree[i].to]) continue; sum[Star]+=DFS(Tree[i].to,Tree[i].w); } if(w==2||sum[Star]>=1) //若该条路需要被修复||子节点已经被修复 { if(sum[Star]==0) //未被记录则加入集合 { Answer[Ansn++]=Star; } return 1; } else //不需要修复 return 0;}int main(){ int n,i,j,a,b,c,ans; while(scanf("%d",&n)!=EOF) { Index=ans=Ansn=0; memset(pre,-1,sizeof(pre)); memset(sum,0,sizeof(sum)); memset(visit,0,sizeof(visit)); for(i=1;i
>更多相关文章
- 09-29如何通过wrap malloc定位C/C++程序的内存泄漏
- 02-25打车软件大战升级,补贴还能维持多久?
- 12-23BMP文件右旋90度[c语言]
- 12-23寻找直方图中面积最大的矩形(C语言版)
- 12-23[ndk,2]ndk开发案例和错误处理
- 12-23[ndk,1]ndk开发,C语言入门讲解
- 12-23C语言连续存储实现队列机制
- 12-23Objective-c 数据类型
首页推荐
佛山市东联科技有限公司一直秉承“一切以用户价值为依归
- 01-11全球最受赞誉公司揭晓:苹果连续九年第一
- 12-09罗伯特·莫里斯:让黑客真正变黑
- 12-09谁闯入了中国网络?揭秘美国绝密黑客小组TA
- 12-09警示:iOS6 惊现“闪退”BUG
- 12-05亚马逊推出新一代基础模型 任意模态生成大模
- 12-05OpenAI拓展欧洲业务 将在苏黎世设立办公室
- 12-05微软质疑美国联邦贸易委员会泄露信息 督促其
- 12-05联交所取消宝宝树上市地位 宝宝树:不会对公
- 12-04企业微信致歉:文档打开异常已完成修复
相关文章
24小时热门资讯
24小时回复排行
热门推荐
最新资讯
操作系统
黑客防御