#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<string>
#include<map>
using namespace std;
map<string,int> nameCache;
int nowID,n;
string boss;
struct Edge
{
int to,next;
}edge[];
int num_edge,first[];
int dp1[][];
bool dp2[][];
bool vis[];
//[][1]表示选此点,[][0]表示不选此点,dp1记录最多选的人数,dp2记录是否唯一
void dp(int x)
{
int k=first[x];
dp2[x][]=true;
dp1[x][]=;
dp2[x][]=true;
dp1[x][]=;
vis[x]=true;
while(k!=)
{
if(!vis[edge[k].to]) dp(edge[k].to);
dp1[x][]+=dp1[edge[k].to][];
dp2[x][]&=dp2[edge[k].to][];
if(dp1[edge[k].to][]>dp1[edge[k].to][])
{
dp1[x][]+=dp1[edge[k].to][];
dp2[x][]&=dp2[edge[k].to][];
}
else if(dp1[edge[k].to][]<dp1[edge[k].to][])
{
dp1[x][]+=dp1[edge[k].to][];
dp2[x][]&=dp2[edge[k].to][];
}
else
{
dp1[x][]+=dp1[edge[k].to][];
dp2[x][]=false;
}
k=edge[k].next;
}
}
int main()
{
int i,t1,t2;
string str,str2;
cin>>n;
while(n!=)
{
cin>>boss;
nameCache.clear();
num_edge=;
nowID=;
nameCache[boss]=;
memset(vis,,sizeof(vis));
memset(first,,sizeof(first));
for(i=;i<n;i++)
{
cin>>str>>str2;
if(nameCache.count(str)==)
{
t1=nowID++;
nameCache[str]=t1;
}
else
t1=nameCache[str];
if(nameCache.count(str2)==)
{
t2=nowID++;
nameCache[str2]=t2;
}
else
t2=nameCache[str2];
edge[++num_edge].to=t1;
edge[num_edge].next=first[t2];
first[t2]=num_edge;
}
dp();
if(dp1[][]>dp1[][])
{
printf("%d ",dp1[][]);
if(dp2[][]==true)
printf("Yes\n");
else
printf("No\n");
}
else if(dp1[][]<dp1[][])
{
printf("%d ",dp1[][]);
if(dp2[][]==true)
printf("Yes\n");
else
printf("No\n");
}
else
printf("%d No\n",dp1[][]);
cin>>n;
}
return ;
}

UVa 1220 Party at Hali-Bula 晚会的更多相关文章

  1. POJ 3342 Party at Hali-Bula / HDU 2412 Party at Hali-Bula / UVAlive 3794 Party at Hali-Bula / UVA 1220 Party at Hali-Bula(树型动态规划)

    POJ 3342 Party at Hali-Bula / HDU 2412 Party at Hali-Bula / UVAlive 3794 Party at Hali-Bula / UVA 12 ...

  2. Uva 1220,Hali-Bula 的晚会

    题目链接:https://uva.onlinejudge.org/external/12/1220.pdf 题意: 公司n个人,形成一个数状结构,选出最大独立集,并且看是否是唯一解. 分析: d(i) ...

  3. UVa 1220 Hali-Bula的晚会(树的最大独立集)

    https://vjudge.net/problem/UVA-1220 题意: 公司里有n个人形成一个树状结构,即除了老板以外每个员工都有唯一的直属上司.要求选尽量多的人,但不能同时选择一个人和他的直 ...

  4. uva 1220

    1220 - Party at Hali-Bula Time limit: 3.000 seconds Dear Contestant, I'm going to have a party at my ...

  5. UVa 1220 - Party at Hali-Bula(树形DP)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  6. UVa 1220 (树的最大独立集) Party at Hali-Bula

    题意: 有一棵树,选出尽可能多的节点是的两两节点不相邻,即每个节点和他的子节点只能选一个.求符合方案的最大节点数,并最优方案判断是否唯一. 分析: d(u, 0)表示以u为根的子树中,不选u节点能得到 ...

  7. UVA - 1220 Party at Hali-Bula 树的最大独立集

    题意:  给定n个人,存在上下级关系,每个人只有一个上级,求最大独立集.并判断最大独立集是否唯一 思路:d[i][0]表示以i为根的子树中,不选择第i个节点的最大独立集,f[i][0]表示以i为根的子 ...

  8. UVa 1220 Party at Hali-Bula (树形DP,最大独立集)

    题意:公司有 n 个人形成一个树形结构,除了老板都有唯一的一个直系上司,要求选尽量多的人,但不能同时选一人上和他的直系上司,问最多能选多少人,并且是不是唯一的方案. 析:这个题几乎就是树的最大的独立集 ...

  9. UVA - 1220 Party at Hali-Bula (树形DP)

    有 n 个员工,n-1个从属关系. 不能同时选择某个员工和他的直接上司,问最多可以选多少人,以及选法是否唯一. 树上的最大独立集问题.只不过多了一个判断唯一性. dp[u][0]表示不选这个点的状态, ...

随机推荐

  1. 简单的shell脚本编写

    http://www.cnblogs.com/wuyuegb2312/p/3399566.html

  2. [翻译]理解Unity的自动内存管理

    当创建对象.字符串或数组时,存储它所需的内存将从称为堆的中央池中分配.当项目不再使用时,它曾经占用的内存可以被回收并用于别的东西.在过去,通常由程序员通过适当的函数调用明确地分配和释放这些堆内存块.如 ...

  3. dede摘要长度,dedecms摘要限制,dedecms摘要字数

    dede摘要长度,dedecms摘要限制,dedecms摘要字数 如果可以有效控制文章摘要的字数,那么就可以使得页面布局很灵活. 在Dedecms中,在列表页调用文章摘要的方法主要有: 1:[fiel ...

  4. eclipse创建maven项目出现以下报错: org.apache.maven.archiver.MavenArchiver.getManifest (org.apache.maven.project.MavenProject,org.apache.mav en.archiver.MavenArchiveConfiguration)

    解决方法: 更新eclipse中的maven插件 Help ->  Install New Software -> add ->  http://repo1.maven.org/ma ...

  5. Swift(二)控制流

    要处理条件逻辑,使用 if 和 switch ,要处理循环逻辑,使用 for-in, for, while, 和 do-while .包着条件或者循环的括号可加可不加.处理逻辑体的花括弧是必须加的. ...

  6. jsp重写url

    众所周知,使用java web编程出来的网站都是.jsp结尾的,而别人的网站都是以.html结尾的,那么这种效果是怎么实现的呢?就是这篇文章产生的原因,jsp重写url需要设计到第三方架包urlrew ...

  7. SideBar---fixed定位

      <style> /*外层fixed*/ body{ width:2000px; height:2000px; background:#000; } .wrap { position: ...

  8. 【CAIOJ1177】 子串是否出现

    [题目链接] 点击打开链接 [算法] KMP [代码] #include<bits/stdc++.h> using namespace std; #define MAXA 1000010 ...

  9. python利用mongodb上传图片数据 : GridFS 与 bson两种方式

    利用mongodb保存图片通常有两种方法,一种是将图片数据转化为二进制作为字典的键值对进行保存,另一种是利用mongodb提供的GridFS进行保存,两者各有利弊.性能方面的优劣未曾测试,无法进行评价 ...

  10. nginx下laravel框架rewrite的设置

    nginx下laravel框架rewrite的设置 百牛信息技术bainiu.ltd整理发布于博客园 在nginx的vhost站点配置文件中加入以下内容即可 1 2 3 4 5 6 7 8 9 10 ...