1003 - Drunk


PDF (English)
Statistics
Forum

Time Limit: 2 second(s)
Memory Limit: 32 MB

One of my friends is always drunk. So, sometimes I get a bit confused whether he is drunk or not. So, one day I was talking to him, about his drinks! He began to describe his way of drinking. So, let me share his ideas a bit. I am expressing in my words.

There are many kinds of drinks, which he used to take. But there are some rules; there are some drinks that have some pre requisites. Suppose if you want to take wine, you should have taken soda, water before it. That's why to get real drunk is not that easy.

Now given the name of some drinks! And the prerequisites of the drinks, you have to say that whether it's possible to get drunk or not. To get drunk, a person should take all the drinks.

Input

Input starts with an integer T (≤ 50), denoting the number of test cases.

Each case starts with an integer m (1 ≤ m ≤ 10000). Each of the next m lines will contain two names each in the format a b, denoting that you must have a before having b. The names will contain at most10 characters with no blanks.

Output

For each case, print the case number and 'Yes' or 'No', depending on whether it's possible to get drunk or not.

Sample Input

2

2

soda wine

water wine

3

soda wine

water wine

wine water

Output for Sample Input

Case 1: Yes

Case 2: No

::学习一个新算法,总没那么容易,今天又因为一个弄错一个字母找了半天*.*!!

   1: #include <iostream>

   2: #include <cstdio>

   3: #include <algorithm>

   4: #include <cstring>

   5: #include <map>

   6: using namespace std;

   7: const int maxn=11000;

   8: int head[maxn],in[maxn];

   9: bool vis[maxn];

  10: int ant,cas=1,id;

  11:  

  12: map<string,int>a;

  13: struct EDGE{

  14:     int v, next;

  15:     EDGE(){}

  16:     EDGE(int _v, int _next){v = _v, next = _next;}

  17: }e[maxn];

  18: int ecnt;

  19:  

  20: void add(int u, int v){

  21:     e[ecnt] = EDGE(v, head[u]);

  22:     head[u] = ecnt++;

  23: }

  24:  

  25: bool topo(){

  26:     memset(vis, 0, sizeof(vis));

  27:  

  28:     for(int t = 0; t < id; t++){

  29:         int u;

  30:         for(u = 0; u < id; u++)

  31:             if(!vis[u] && !in[u])

  32:                 break;

  33:         if(u >= id)

  34:             return false;

  35:  

  36:         vis[u] = true;

  37:         in[u]--;

  38:         for(int i = head[u]; i != -1; i = e[i].next){

  39:             int v = e[i].v;

  40:             in[v]--;

  41:         }

  42:     }

  43:     return true;

  44: }

  45:  

  46: void solve()

  47: {

  48:     int n;

  49:     ecnt=0,id=0;

  50:     a.clear();

  51:     memset(head,-1,sizeof(head));

  52:     memset(in,0,sizeof(in));

  53:     cin>>n;

  54:  

  55:     while(n--)

  56:     {

  57:         string x,y;

  58:         cin>>x>>y;

  59:  

  60:         if(a.find(x)==a.end()) a[x]=id++;

  61:         if(a.find(y)==a.end()) a[y]=id++;

  62:         int u=a[x],v=a[y];

  63:         add(u,v);

  64:         in[v]++;

  65:     }

  66:     if(topo())

  67:         cout<<"Yes"<<endl;

  68:     else

  69:         cout<<"No"<<endl;

  70: }

  71:  

  72: int main()

  73: {

  74:     ios::sync_with_stdio(false);

  75:     int t, cas = 0;

  76:     cin>>t;

  77:     while(t--){

  78:         cout<<"Case "<< (++cas)<<": ";

  79:         solve();

  80:     }

  81:     return 0;

  82: }

Loj 1003–Drunk(拓扑排序)的更多相关文章

  1. Lightoj 1003 - Drunk(拓扑排序)

    One of my friends is always drunk. So, sometimes I get a bit confused whether he is drunk or not. So ...

  2. Lightoj 1003 - Drunk(拓扑排序判断是否有环 Map离散化)

    题目链接:http://lightoj.com/volume_showproblem.php?problem=1003 题意是有m个关系格式是a b:表示想要和b必须喝a,问一个人是否喝醉就看一个人是 ...

  3. [LOJ 3101] [Luogu 5332] [JSOI2019]精准预测(2-SAT+拓扑排序+bitset)

    [LOJ 3101] [Luogu 5332] [JSOI2019]精准预测(2-SAT+拓扑排序+bitset) 题面 题面较长,略 分析 首先,发现火星人只有死和活两种状态,考虑2-SAT 建图 ...

  4. 洛谷 P3975 / loj 2102 [TJOI2015] 弦论 题解【后缀自动机】【拓扑排序】

    后缀自动机入门. 题目描述 为了提高智商,ZJY 开始学习弦论. 这一天,她在<String theory>中看到了这样一道问题:对于一个给定的长度为 \(n\) 的字符串,求出它的第 \ ...

  5. 洛谷 P3244 / loj 2115 [HNOI2015] 落忆枫音 题解【拓扑排序】【组合】【逆元】

    组合计数的一道好题.什么非主流题目 题目背景 (背景冗长请到题目页面查看) 题目描述 不妨假设枫叶上有 \(n​\) 个穴位,穴位的编号为 \(1\sim n​\).有若干条有向的脉络连接着这些穴位. ...

  6. 洛谷P4332 [SHOI2014]三叉神经树(LCT,树剖,二分查找,拓扑排序)

    洛谷题目传送门 你谷无题解于是来补一发 随便百度题解,发现了不少诸如树剖\(log^3\)LCT\(log^2\)的可怕描述...... 于是来想想怎么利用题目的性质,把复杂度降下来. 首先,每个点的 ...

  7. LightOJ1003---Drunk(拓扑排序判环)

    One of my friends is always drunk. So, sometimes I get a bit confused whether he is drunk or not. So ...

  8. HDU2094产生冠军 (拓扑排序)

    HDU2094产生冠军 Description 有一群人,打乒乓球比赛,两两捉对撕杀,每两个人之间最多打一场比赛. 球赛的规则如下: 如果A打败了B,B又打败了C,而A与C之间没有进行过比赛,那么就认 ...

  9. LightOJ - 1003 Drunk

    One of my friends is always drunk. So, sometimes I get a bit confused whether he is drunk or not. So ...

随机推荐

  1. MVC应用程序结构与规划

    对MVC好长一段时间练习,说句实在的话,还有很多是感到陌生,很多是生疏...... 很多网友也是刚想学习MVC,看到Insus.NET每学习一种方法,一个技巧均写成博文,也很希望能获取到练习的源程序以 ...

  2. Python入门笔记(22):Python函数(5):变量作用域与闭包

    一.全局变量与局部变量 一个模块中,最高级别的变量有全局作用域. 全局变量一个特征就是:除非被删除,否则他们存活到脚本运行结束,且对于所有的函数都可访问. 当搜索一个标识符(也称变量.名字等),Pyt ...

  3. DotNetBar的初步使用

    以前有用过SkinSharp和IrisSkin2皮肤控件来美化UI,简单易用,但不方便自定义.而DotNetBar功能很强大,不仅有Windows2007风格,更有Ribbon风格的界面效果.其效果演 ...

  4. 将C1Chart数据导出到Excel

    大多数情况下,当我们说将图表导出到Excel时,意思是将Chart当成图片导出到Excel中.如果是这样,你可以参考帮助文档中保存和导出C1Chart章节. 不过,也有另一种情况,当你想把图表中的数据 ...

  5. 利用Spring创建定时任务

    啊Spring Task看似很简单的感觉,但是自己搞起来还是花了蛮大的精力的,因为以前没接触过这个东西,所有当任务交给我的时候,我是一头的雾水的.然后我就各种查资料.其中我印象最深的是版本的问题和架包 ...

  6. 从零开始学习Linux(mkdir and rmdir)

    今天说mkdir 和 rmdir.因为mkdir 内容比较少.而且也很好理解. 对于mkdir来说,一般只用到 -p -m,我只用过-p参数,-m也是刚刚看的. 先说不带参数的: mkdir  tes ...

  7. (转)x11vnc配置--ubuntu14.04

    原文网址:http://www.cnblogs.com/elmaple/p/4354814.html x11vnc是连接到真实的X会话,相比vnc4server和tightvncserver自己创建不 ...

  8. 在Android设备上判断设备是否支持摄像头

    private boolean hasCamera(){ boolean hasCamera=false; PackageManager pm=getActivity().getPackageMana ...

  9. linux下firefox手工安装flash插件

    1. 前往adobe官网,下载flash安装包.下载.tar.gz安装包即可.2. 解压安装包,得到libflashplayer.so文件3. 新建文件夹,~/.mozilla/plugins4. 拷 ...

  10. 一个页面从输入 URL 到页面加载完的过程中都发生了什么事情?

    过程概述 浏览器查找域名对应的 IP 地址: 浏览器根据 IP 地址与服务器建立 socket 连接: 浏览器与服务器通信: 浏览器请求,服务器处理请求: 浏览器与服务器断开连接. 以下为详细解析: ...