伪Acmer的推理(dfs/bfs)
时间限制: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)的更多相关文章
- 17232 伪Acmer的推理(传递闭包)
17232 伪Acmer的推理 时间限制:1000MS 内存限制:65535K提交次数:0 通过次数:0 收入:0 题型: 编程题 语言: G++;GCC Description 现在正是期末, ...
- DFS/BFS+思维 HDOJ 5325 Crazy Bobo
题目传送门 /* 题意:给一个树,节点上有权值,问最多能找出多少个点满足在树上是连通的并且按照权值排序后相邻的点 在树上的路径权值都小于这两个点 DFS/BFS+思维:按照权值的大小,从小的到大的连有 ...
- 【DFS/BFS】NYOJ-58-最少步数(迷宫最短路径问题)
[题目链接:NYOJ-58] 经典的搜索问题,想必这题用广搜的会比较多,所以我首先使的也是广搜,但其实深搜同样也是可以的. 不考虑剪枝的话,两种方法实践消耗相同,但是深搜相比广搜内存低一点. 我想,因 ...
- ID(dfs+bfs)-hdu-4127-Flood-it!
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4127 题目意思: 给n*n的方格,每个格子有一种颜色(0~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 ...
- HDU 4771 (DFS+BFS)
Problem Description Harry Potter has some precious. For example, his invisible robe, his wand and hi ...
- DFS/BFS视频讲解
视频链接:https://www.bilibili.com/video/av12019553?share_medium=android&share_source=qq&bbid=XZ7 ...
- POJ 3083 -- Children of the Candy Corn(DFS+BFS)TLE
POJ 3083 -- Children of the Candy Corn(DFS+BFS) 题意: 给定一个迷宫,S是起点,E是终点,#是墙不可走,.可以走 1)先输出左转优先时,从S到E的步数 ...
- [LeetCode]695. 岛屿的最大面积(DFS/BFS)、200. 岛屿数量(DFS/BFS待做/并差集待做)
695. 岛屿的最大面积 题目 给定一个包含了一些 0 和 1的非空二维数组 grid , 一个 岛屿 是由四个方向 (水平或垂直) 的 1 (代表土地) 构成的组合.你可以假设二维矩阵的四个边缘都被 ...
随机推荐
- 【编程题目】和为 n 连续正数序列
51.和为 n 连续正数序列(数组).题目:输入一个正数 n,输出所有和为 n 连续正数序列.例如输入 15,由于 1+2+3+4+5=4+5+6=7+8=15,所以输出 3 个连续序列 1-5. 4 ...
- Json数据报错
在Json数据解析的时候报错,如下图: 这里的id,code,A1等等,都应该使用双引号,即:"id","code","A1",假如id后面 ...
- CSS实现限制显示的字数,超出显示"..."
一.背景 在实际项目中,我们常常需要对某些页面的某些特定区域显示指定数量的内容,超出的内容显示"..."来进行美化页面,那么应该怎么做呢?今天就让我们来看看如何达到这一效果. 二. ...
- hdu5878(枚举,打表)
题目链接:hdu5878 题意:到一行输入t,表示下面有t组数据,然后下面t行每行输入一个数n; 定义x==2^a*3^b*5^c*7^d(a, b, c, d为自然数,x不大于1e+9): 要求对于 ...
- UML类图五种关系与代码的对应关系
转: UML类图中的五种关系的耦合强弱比较:依赖<关联<聚合<组合<继承 一.依赖关系: (一)说明 虚线+箭头 可描述为:Uses a 依赖是类的五种关系中耦合最小的一种关系 ...
- C/C++学习笔记----指针的理解
指针是C/C++编程中的重要概念之一,也是最容易产生困惑并导致程序出错的问题之一.利用指针编程可以表示各种数据结构,通过指针可使用主调函数和被调函数之间共享变量或数据结构,便于实现双向数据通讯:指针能 ...
- Oracle RAC 连接
http://blog.csdn.net/hijk139/article/details/7452553 http://blog.itpub.net/4227/viewspace-677272/ ht ...
- 64位Ubuntu运行32位程序时报文件不存在(No such file or Directory)的一种解决办法
尝试在64位Ubuntu下面运行32位程序时, 一直说 文件不存在(No such file or directory), 我只想说++. 你tm说个文件格式不正确不就好了? 非得说个文件不存在! 真 ...
- Linux 配置NFS,文件共享
配置: 1.设定共享主机服务器 ---(注意防火墙) 编辑ipA端的/etc/exports 文件 [root@dbrac2 ~]# cat /etc/exports /media 192 ...
- c/s模式 (C#)下Ftp的多文件上传及其上传进度
因为项目要求,制作的一个多文件上传,并显示进度条一段代码(vs2005环境).(只为粗略的实现,代码并不规范) 当多个文件上传的时候,需要依次队列形式一个个上传,当上传某个文件的时候,锁定进程,上传完 ...