当前位置:网站首页>L2-010 排座位 (25 分) (DFS)
L2-010 排座位 (25 分) (DFS)
2022-08-08 16:51:00 【Here_SDUT】
布置宴席最微妙的事情,就是给前来参宴的各位宾客安排座位。无论如何,总不能把两个死对头排到同一张宴会桌旁!这个艰巨任务现在就交给你,对任何一对客人,请编写程序告诉主人他们是否能被安排同席。
输入格式: 输入第一行给出3个正整数:N(≤100),即前来参宴的宾客总人数,则这些人从1到N编号;M为已知两两宾客之间的关系数;K为查询的条数。随后M行,每行给出一对宾客之间的关系,格式为:宾客1 宾客2 关系,其中关系为1表示是朋友,-1表示是死对头。注意两个人不可能既是朋友又是敌人。最后K行,每行给出一对需要查询的宾客编号。
这里假设朋友的朋友也是朋友。但敌人的敌人并不一定就是朋友,朋友的敌人也不一定是敌人。只有单纯直接的敌对关系才是绝对不能同席的。
输出格式: 对每个查询输出一行结果:如果两位宾客之间是朋友,且没有敌对关系,则输出No problem;如果他们之间并不是朋友,但也不敌对,则输出OK;如果他们之间有敌对,然而也有共同的朋友,则输出OK but...;如果他们之间只有敌对关系,则输出No way。
输入样例:
7 8 4
5 6 1
2 7 -1
1 3 1
3 4 1
6 7 -1
1 2 1
1 4 1
2 3 -1
3 4
5 7
2 3
7 2输出样例:
No problem
OK
OK but...
No way分析 N \le 100,说明可以直接建图后进行dfs遍历,只遍历边权为1的点,如果可以从a走到b,说明有共同朋友,在判断mp[a][b]是否为-1即可。其他情况类似。
代码
// _ooOoo_
// o8888888o
// 88" . "88
// (| -_- |)
// O\ = /O
// ____/`---'\____
// . ' \| |// `.
// / \||| : |||// \
// / _||||| -:- |||||- \
// | | \\ - /// | |
// | \_| ''\---/'' | |
// \ .-\__ `-` ___/-. /
// ___`. .' /--.--\ `. . __
// ."" '< `.___\_<|>_/___.' >'"".
// | | : `- \`.;`\ _ /`;.`/ - ` : | |
// \ \ `-. \_ __\ /__ _/ .-` / /
// ======`-.____`-.___\_____/___.-`____.-'======
// `=---='
//
// .............................................
// 佛祖保佑 一发AC 永无BUG
#include <bits/stdc++.h>
#define LL long long
using namespace std;
const int maxn = 1e5 + 10;
const int inf = 0x3f3f3f3f;
const double PI = acos(-1.0);
typedef pair<int, int> PII;
int n, m, k, a, b, c;
int mp[111][111];
bool dfs(int now, int end,int fa) {
if (now == end) return true;
for (int i = 1; i <= n; i++) {
if(i == fa) continue;
if (mp[i][now] == 1) {
if (dfs(i, end,now)) return true;
}
}
return false;
}
int main(int argc, char const *argv[]) {
cin >> n >> m >> k;
for (int i = 0; i < m; i++) {
cin >> a >> b >> c;
mp[a][b] = c;
mp[b][a] = c;
}
while (k--) {
cin >> a >> b;
if (dfs(a, b,-1)) {
if (mp[a][b] != -1)
puts("No problem");
else
puts("OK but...");
} else {
if (mp[a][b] == -1)
puts("No way");
else
puts("OK");
}
}
return 0;
}边栏推荐
- 京东二面:高并发设计,都有哪些技术方案?
- Patience sorting - specializing in quickly solving the longest increasing subarray
- 4. S32K14X study notes: S32 Design Studio new and imported projects
- 3531. 哈夫曼树
- ESP8266-Arduino编程实例-ADS1015(ADC)驱动
- iNFTnews | 元宇宙为企业发展带来新思路
- 第二十章 源代码文件 REST API 参考(二)
- 敏捷开发项目管理的一些心得
- 最稳定的淘宝商品详情接口
- Building and Visualizing Sudoku Games with Pygame
猜你喜欢
随机推荐
4、S32K14X学习笔记:S32 Design Studio 新建和导入工程
【 8.7 】 source code - card to LCM with GCD 】 【 】
leetcode:306. 累加数
永续合约交易所系统开发逻辑详情
QCon 回顾 | Data Fabric:逻辑统一、物理分散
R语言4.04安装教程
PNAS最新研究:81%解题率,神经网络 Codex 推开高等数学世界大门
Spam accounts are a lot of trouble, and device fingerprints are quickly found
敏捷开发项目管理的一些心得
D. Non-zero Segments
4. S32K14X study notes: S32 Design Studio new and imported projects
Solve the inexplicable problem of MySQL violently - restart the service!
VISTA无人驾驶模拟器;FinRL量化金融深度强化学习库;『深度神经网络应用』电子书;CUDA/TensorRT案例集锦;前沿论文 | ShowMeAI资讯日报
【MySQL哪些字段适合建索引,哪些查询条件会导致索引失效】
DASCTF部分复现
L2-024 部落 (25 分)(并查集)
JVM-简介&垃圾回收&内存泄漏分析
Obtain - 64 [chances] : the soldier, subtlety also - 5 - read sun tzu - melee meter
Nervegrowold: machine advanced learning advice
第二十章 源代码文件 REST API 参考(二)









