时间限制:1000MS  内存限制:65535K
提交次数:12 通过次数:9

收入:32

题型: 编程题   语言: C++;C

Description

现在正是期末,在复习离散数学的Acmer遇到了问题,你能帮助他吗?
Acmer正在复习的是推理,不过他的推理系统可能与别人的不一样。
(所以说他是一个伪Acmer~。做完这题,请自觉把这里伪Acmer自己定义的概念忘了。。否则到时学离散的时候混淆了概念的话自重。。。)
他的推理系统定义如下:
1.用大写英文字母A-Z表示一个命题。
2.用A→B表示若命题A成立则命题B成立。
3.用A↔B表示A→B且B→A。
(这里2,3皆表示一种逻辑关系。)
推理就是由若干个命题或逻辑关系出发,推出新的命题或逻辑关系。
如,已知A→B和B→C,我们可以推出A→C。
又如,已知A→B和A,我们可以推出B。
再如,如果仅有A、B成立,是不可以推出A→B的。
。。。。。。
现在Acmer已经知道了n个命题或逻辑关系是成立的。而且,他从这些前提出发,又推出了m个新的命题或逻辑关系出来。
不过,他的推理过程并不一定正确。所以,你能告诉他这m个结论中哪些是正确的,哪些是错误的吗?

输入格式

单case输入。
第一行是一个整数n(0<=n<=100)。
接下来n行,每行表示1个已知成立的命题或逻辑关系。
每行首先是一个数字x(1<=x<=3),
  若是1,后面接一个大写英文字母,表示一个命题。
  若是2,后面接两个大写英文字母,表示逻辑关系→。
  若是3,后面接两个大写英文字母,表示逻辑关系↔。
接着是一个整数m(0 < m <= 100)。
接下来m行,每行表示1个要求判断正误的命题或逻辑关系。
每行的格式同上。

输出格式

输出m行。对每个要你判断的结论,正确的话输出“yes”,否则输出“no”。

输入样例

Sample#1:
2
2 A B
2 B C
1
2 A C Sample#2:
1
2 A B
1
1 B Sample#3:
2
2 A B
1 A
1
1 B

输出样例

Sample#1:
yes Sample#2:
no Sample#3:
yes

提示

Sample#不是输入输出的一部分。
注意区别命题和逻辑关系成立的不同。 思路:直接dfs暴力搜一遍,被坑了一下(花了1积分)囧 例子:
0
1
3    Z    Z
答案应该是 yes
/*time  memy
31ms 3854k
by orc
2015 4 16
*/
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream>
#include <vector>
using namespace std;
int vis[], vis2[];
int n, x;
int t;
char u, v, k;
vector<int> G[];
void read_graph()
{
cin >> n;
memset(vis,,sizeof vis );
for(int i = ; i < n; ++i)
{
cin >> t;
if(t == ) { cin >> k; vis[k - 'A'] = ; continue; }//单个点直接标记为成立
else if(t == ) { cin >> u >> v; G[u-'A'].push_back(v - 'A'); }
else { cin >> u >> v; G[u-'A'].push_back(v - 'A'); G[v - 'A'].push_back(u - 'A'); }
}
}
void dfs_pre(int m)
{
vis[m] = ;
int num = G[m].size();
for(int i = ; i < num; ++i)
if(! vis[ G[m][i] ]) dfs_pre(G[m][i]);
}
int dfs(int m,int tag)
{
int i;
vis2[m] = ;
if(m == tag) return ;
int num = G[m].size();
for(i = ; i < num ; ++i)
if(! vis2[ G[m][i] ] ) { if(dfs(G[m][i],tag)) return ; }
if(i >= num ) return ;
}
void solve()
{
int i;
read_graph();
for(i= ;i < ; ++i)//扫一遍,若某结点之前标记了,其邻接点也是成立的
if(vis[i]) dfs_pre(i);
cin >> x;
while(x --)
{
cin >> t;
if(t == ) {
cin >> k;
if(vis[k - 'A']) cout << "yes" <<endl;
else cout << "no" <<endl;
continue;
}
if(t == ){
memset(vis2, ,sizeof vis2 );
cin >> u >> v;
if(u == v) { cout << "yes" <<endl; continue; }//特判
int num = G[u - 'A'].size();
for(i = ; i < num; ++i)
if(! vis2[ G[u - 'A'][i] ]) { if(dfs(G[u - 'A'][i],v - 'A')) break; }
if(i >= num) cout << "no" <<endl;
else cout << "yes" <<endl;
}
else{
memset(vis2, ,sizeof vis2 );
cin >> u >> v;
if(u == v) { cout << "yes" <<endl; continue; }//特判
int leap , leap2;
int num, num2;
leap = leap2 = ;
num = G[u - 'A'].size();
num2 = G[v - 'A'].size();
for(i = ; i < num; ++i)//从 u->v 扫一遍u的邻接点
if(! vis2[ G[u - 'A'][i] ]) { if(leap = dfs(G[u - 'A'][i],v - 'A')) break; }
memset(vis2 , ,sizeof vis2);
for(i = ; i< num2 ; ++i)//从 v->u 扫一遍v的邻接点
if(! vis2[ G[v - 'A'][i] ]) { if(leap2 = dfs(G[v - 'A'][i],u - 'A')) break; }
if(leap && leap2) cout << "yes" <<endl;
else cout << "no" <<endl;
}
}
}
int main()
{
ios::sync_with_stdio();
solve();
return ;
}
/*坑爹例子
0
1
3 Z Z
ans:yes
*/

伪Acmer的推理(dfs/bfs)的更多相关文章

  1. 17232 伪Acmer的推理(传递闭包)

    17232 伪Acmer的推理 时间限制:1000MS  内存限制:65535K提交次数:0 通过次数:0 收入:0 题型: 编程题   语言: G++;GCC Description 现在正是期末, ...

  2. DFS/BFS+思维 HDOJ 5325 Crazy Bobo

    题目传送门 /* 题意:给一个树,节点上有权值,问最多能找出多少个点满足在树上是连通的并且按照权值排序后相邻的点 在树上的路径权值都小于这两个点 DFS/BFS+思维:按照权值的大小,从小的到大的连有 ...

  3. 【DFS/BFS】NYOJ-58-最少步数(迷宫最短路径问题)

    [题目链接:NYOJ-58] 经典的搜索问题,想必这题用广搜的会比较多,所以我首先使的也是广搜,但其实深搜同样也是可以的. 不考虑剪枝的话,两种方法实践消耗相同,但是深搜相比广搜内存低一点. 我想,因 ...

  4. ID(dfs+bfs)-hdu-4127-Flood-it!

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4127 题目意思: 给n*n的方格,每个格子有一种颜色(0~5),每次可以选择一种颜色,使得和左上角相 ...

  5. [LeetCode] 130. Surrounded Regions_Medium tag: DFS/BFS

    Given a 2D board containing 'X' and 'O' (the letter O), capture all regions surrounded by 'X'. A reg ...

  6. HDU 4771 (DFS+BFS)

    Problem Description Harry Potter has some precious. For example, his invisible robe, his wand and hi ...

  7. DFS/BFS视频讲解

    视频链接:https://www.bilibili.com/video/av12019553?share_medium=android&share_source=qq&bbid=XZ7 ...

  8. POJ 3083 -- Children of the Candy Corn(DFS+BFS)TLE

    POJ 3083 -- Children of the Candy Corn(DFS+BFS) 题意: 给定一个迷宫,S是起点,E是终点,#是墙不可走,.可以走 1)先输出左转优先时,从S到E的步数 ...

  9. [LeetCode]695. 岛屿的最大面积(DFS/BFS)、200. 岛屿数量(DFS/BFS待做/并差集待做)

    695. 岛屿的最大面积 题目 给定一个包含了一些 0 和 1的非空二维数组 grid , 一个 岛屿 是由四个方向 (水平或垂直) 的 1 (代表土地) 构成的组合.你可以假设二维矩阵的四个边缘都被 ...

随机推荐

  1. 解决Odoo出现的Unable to send email, please configure the sender's email address or alias.

    这是由于当前登录用户的邮件地址信息缺失造成的,需要设置其邮件地址. 方法:使用创建该用户的管理员帐号登录系统,开启技术特性,在需要设置邮箱地址的用户界面点击相关的业务伙伴标签链接,如图所示:

  2. java获取客服端信息(系统,浏览器等)

    String agent = request.getHeader("user-agent"); System.out.println(agent); StringTokenizer ...

  3. js方法类库封装的简易示例

    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></s ...

  4. [Android Pro] Android 官方推荐 : DialogFragment 创建对话框

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/37815413 1. 概述 DialogFragment在android 3.0时 ...

  5. August 10th, 2016, Week 33rd, Wednesday

    The degree of loving is measured by the degree of giving. 爱的深浅是用给与的多少来衡量的. Some say that if you love ...

  6. CountdownLatchTest

    import java.util.concurrent.CountDownLatch; import java.util.concurrent.ExecutorService; import java ...

  7. 合唱队形2(洛谷U5874)

    题目背景 上次老师挑出来的(N-K)位同学很不高兴,于是他们准备自己组建合唱队形.他们请了kkk来帮忙. 题目描述 他们安排了一个动作--手拉着手唱一首歌(就是他们围成一个圈).如果有两个相邻的同学的 ...

  8. hdu1141(二进制数位,二分,打表)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1141 题意:××公司是制造computer的,1960年它造的computer是4bit的,之后每10 ...

  9. PAL/NTSC 制电视广播技术有关知识--FPGA

    1.PAL和NTSC的区别 常见的电视信号制式是PAL和NTSC,另外还有SECAM等. NTSC即正交平衡调幅制,PAL为逐行倒像正交平衡调幅制. (1)PAL电视标准  PAL电视标准,每秒25帧 ...

  10. Android Programming: Pushing the Limits -- Chapter 7:Android IPC -- Messenger

    Messenger类实际是对Aidl方式的一层封装.本文只是对如何在Service中使用Messenger类实现与客户端的通信进行讲解,对Messenger的底层不做说明.阅读Android Prog ...