poj 3342 Party at Hali-Bula(트리 dp)
#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;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.