poj 3342 Party at Hali-Bula(树形dp)
来源:互联网 发布:蒙文软件下载 编辑:程序博客网 时间:2024/05/16 11:31
树上的最大独立集, 树形dp水题。不过第二问判断解是否唯一还是第一次接触到。。。dp[i][0]表示i节点不取得到的最大集,dp[i][1]表示i节点取得到的最大集。用num数组记录当前状态数是否唯一。
#include<iostream>#include<algorithm>#include<vector>#include<cstdio>#include<cstring>#include<string>#include<map>using namespace std;const int maxn = 201;int dp[maxn][2], num[maxn][2], n, cnt;map<string, int> s;vector<int> G[maxn];int id(string a){ if(s.count(a)) return s[a]; else s[a] = cnt++; return cnt - 1;}void dfs(int u){ dp[u][0] = 0; num[u][0] = num[u][1] = dp[u][1] = 1; int nc = G[u].size(); for(int i=0; i<nc; i++) { int v = G[u][i]; dfs(v); if(dp[v][1] || dp[v][0]) { dp[u][0] += max(dp[v][1], dp[v][0]); if(dp[v][1] == dp[v][0]) num[u][0]++; else if(dp[v][1] > dp[v][0] && num[v][1] > 1) num[u][0]++; else if(dp[v][0] > dp[v][1] && num[v][0] > 1) num[u][0]++; } if(dp[v][0]) { dp[u][1] += dp[v][0]; if(num[v][0] > 1) num[u][1]++; } }}int main(){ while(cin>>n, n) { for(int i=0; i<=n; i++) G[i].clear(); s.clear(); cnt = 0; string a, b; int rt, aa, bb; cin>>a; rt = id(a); for(int i=1; i<n; i++) { cin>>a>>b; aa = id(a); bb = id(b); G[bb].push_back(aa); } dfs(rt); int flag; if(dp[0][0] == dp[0][1]) flag = num[0][1] + num[0][0]; else if(dp[0][0] > dp[0][1]) flag = num[0][0]; else flag = num[0][1]; int ans = max(dp[0][0], dp[0][1]); cout<<ans<<" "; if(flag > 1) cout<<"No"<<endl; else cout<<"Yes"<<endl; } return 0;}
- poj 3342 Party at Hali-Bula 树形dp
- poj 3342 Party at Hali-Bula(树形dp)
- POJ 3342 Party at Hali-Bula(树形DP)
- Party at Hali-Bula - POJ 3342 树形dp
- POJ - 3342 Party at Hali-Bula 树形DP
- [poj 3342]Party at Hali-Bula 树形dp
- poj 3342 Party at Hali-Bula(树形dp)
- POJ 3342 Party at Hali-Bula(树形DP)
- Party at Hali-Bula-----树形dp
- 【树形DP】Party at Hali-Bula
- POJ3342 Party at Hali-Bula 树形DP
- HDU2421 Party at Hali-Bula 树形DP
- Party at Hali-Bula(树形dp)
- POJ3342 Party at Hali-Bula(树形DP)
- pku 3342 Party at Hali Bula 树形dp 解题报告
- 树形动态规划 POJ 3342 Party at Hali-Bula
- POJ 3342 - Party at Hali-Bula 树形DP+最优解唯一性判断
- poj 3342 Party at Hali-Bula(树形DP+判断方式是不是唯一)
- Tomcat 7.0 Manager 访问需要用户名与密码
- 重命名数据库服务器
- 第十二堂课后作业
- MySQL性能优化
- 观察者模式-----Observer-------
- poj 3342 Party at Hali-Bula(树形dp)
- lc振荡电路是如何起振的?
- java 键盘输入的几种方法比较
- 安装Tomcat没设置账号和密码,tomcat网页中打开Manager App等报错(Tomcat6及以下版本)
- ios将库项目编译成framework
- 话说软件破解:道高一尺魔高一丈
- 数据库网站
- hdu1086 You can Solve a Geometry Problem too
- hdoj_2027 统计元音