hdu-----(4514)湫湫系列故事——设计风景线(树形DP+并查集)
湫湫系列故事——设计风景线
Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Total Submission(s): 3105 Accepted Submission(s): 562
Problem Description
随着杭州西湖的知名度的进一步提升,园林规划专家湫湫希望设计出一条新的经典观光线路,根据老板马小腾的指示,新的风景线最好能建成环形,如果没有条件建成环形,那就建的越长越好。 现在已经勘探确定了n个位置可以用来建设,在它们之间也勘探确定了m条可以设计的路线以及他们的长度。请问是否能够建成环形的风景线?如果不能,风景线最长能够达到多少? 其中,可以兴建的路线均是双向的,他们之间的长度均大于0。
Input
测试数据有多组,每组测试数据的第一行有两个数字n, m,其含义参见题目描述; 接下去m行,每行3个数字u v w,分别代表这条线路的起点,终点和长度。 [Technical Specification] 1. n<=100000 2. m <= 1000000 3. 1<= u, v <= n 4. w <= 1000
Output
对于每组测试数据,如果能够建成环形(并不需要连接上去全部的风景点),那么输出YES,否则输出最长的长度,每组数据输出一行。
Sample Input
3 3 1 2 1 2 3 1 3 1 1
Sample Output
YES
Source
思路> 初看此题,以为是一个单向的路径,于是自己狂写,最后写道一百多行,发现逗逼了一回,是无向图,于是改用并查集(来判断是否有环),最后只剩下求最长路劲了,其实对于这样一个没有方向的图,我们可以去等效于一个链子,只需要找到那些链子的头,然后对于这些头每一个dfs(当然可以去剪纸),最后就可以得到我们要求的了.......
代码:
1 #include<cstdio>
2 #include<cstring>
3 #include<cstdlib>
4 #include<iostream>
5 #include<vector>
6 #include<algorithm>
7 //#pragma comment(linker, "/STACK:36777216,36777216")
8 using namespace std;
9 const int maxn=100005;
10 int father[maxn];
11 bool vis[maxn];
12 int indeg[maxn];
13 int ans,n,m;
14 struct no
15 {
16 int next;
17 int sum;
18 };
19
20 vector<no>tree[maxn];
21
22 void init(int n){
23 ans=-1;
24 tree[0].clear();
25 for(int i=1;i<=n;i++){
26 father[i]=i;
27 tree[i].clear();
28 }
29 memset(vis,0,sizeof(vis));
30 memset(indeg,0,sizeof(int)*(n+1));
31 }
32
33 int find(int a)
34 {
35 while(a!=father[a])
36 a=father[a];
37 return a;
38 }
39 void dfs(int pos,int res)
40 {
41 ans=max(ans,res);
42 int len=tree[pos].size();
43 for(int i=0;i<len;i++)
44 {
45 if(vis[tree[pos][i].next]==0)
46 {
47 vis[tree[pos][i].next]=1;
48 dfs(tree[pos][i].next,res+tree[pos][i].sum);
49 vis[tree[pos][i].next]=0;
50 }
51 }
52 }
53
54 int main()
55 {
56 int i,x,y,aa,bb,cc;
57 bool flag;
58 while(scanf("%d%d",&n,&m)!=EOF)
59 {
60 init(n);
61 flag=0;
62 for(i=1;i<=m;i++){
63 scanf("%d%d%d",&aa,&bb,&cc);
64 indeg[aa]++;
65 indeg[bb]++;
66 tree[aa].push_back((no){bb,cc}); //无向图
67 tree[bb].push_back((no){aa,cc});
68 if(!flag){
69 x=find(aa);
70 y=find(bb);
71 if(x==y) flag=1;
72 else father[y]=x;
73 }
74 }
75 if(flag)printf("YESn");
76 else{
77 //寻找端点
78 for(int i=1;i<=n;i++) {
79 if(indeg[i]==1)
80 tree[0].push_back((no){i,0}); //将多源汇集到一点
81 }
82 vis[0]=1;
83 dfs(0,0);
84 printf("%dn",ans);
85 }
86 }
87 return 0;
88 }
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- FlutterDojo设计之道—状态管理之路(四)
- FlutterDojo设计之道—状态管理之路(五)
- Python高级进阶(一)Python框架之Django入门
- python 自动化测试(2):针对密码输入框为密码控件时的解决方案
- 微信小程序开发之视图容器swiper
- WINDOWS服务器同时安装多个版本的MYSQL的方法,MQYSQL5和MQYSQL8的共存。
- 使用PHP对接国外的PAYPAL支付最新REST API接口。
- golang 学习(10): 使用go语言调用c语言的so动态库
- Django的form,model自定制
- 排序算法与查找算法
- nginx学习(1): openresty安装
- 2020年8月26日更新WINDOWS服务器同时安装多个版本的MYSQL的方法,MQYSQL5和MQYSQL8的共存。
- python 自动化测试(3):数据库连接与使用
- 微信小程序实战开发二:微信小程序 WEUL组件之 画廊组件
- 关于Cookie和Session