66 lines
1.1 KiB
C++
66 lines
1.1 KiB
C++
#include<cstdio>
|
|
#include<iostream>
|
|
#include<string>
|
|
#include<algorithm>
|
|
#include<vector>
|
|
#include<map>
|
|
using namespace std;
|
|
const int maxn=200+5;
|
|
int cnt;
|
|
vector<int> sons[maxn];
|
|
int n,d[maxn][2],f[maxn][2];
|
|
map<string,int> hsh;
|
|
inline int ID(const string& s)
|
|
{
|
|
if(!hsh.count(s)) hsh[s]=cnt++;
|
|
return hsh[s];
|
|
}
|
|
int dp(int u,int k)
|
|
{
|
|
f[u][k]=true;
|
|
d[u][k]=k;
|
|
for(int i=0;i<sons[u].size();i++)
|
|
{
|
|
int v=sons[u][i];
|
|
if(k==1)
|
|
{
|
|
d[u][1]+=dp(v,0);
|
|
if(!f[v][0]) f[u][1]=0;
|
|
}
|
|
else
|
|
{
|
|
d[u][0]+=max(dp(v,0),dp(v,1));
|
|
if(d[v][0]==d[v][1]) f[u][k]=false;
|
|
else if(d[v][0]>d[v][1]&&!f[v][0]) f[u][k]=false;
|
|
else if(d[v][1]>d[v][0]&&!f[v][1]) f[u][k]=false;
|
|
}
|
|
}
|
|
return d[u][k];
|
|
}
|
|
int main()
|
|
{
|
|
#ifdef local
|
|
freopen("pro.in","r",stdin);
|
|
#endif
|
|
string s,s2;
|
|
while(cin>>n>>s)
|
|
{
|
|
cnt=0;
|
|
hsh.clear();
|
|
for(int i=0;i<=n;i++) sons[i].clear();
|
|
ID(s);
|
|
for(int i=0;i<n-1;i++)
|
|
{
|
|
cin>>s>>s2;
|
|
sons[ID(s2)].push_back(ID(s));
|
|
}
|
|
printf("%d ",max(dp(0,0),dp(0,1)));
|
|
bool flag=false;
|
|
if(d[0][0]>d[0][1]&&f[0][0]) flag=true;
|
|
if(d[0][1]>d[0][0]&&f[0][1]) flag=true;
|
|
if(flag) printf("Yes\n");
|
|
else printf("No\n");
|
|
}
|
|
return 0;
|
|
}
|