HDU 5961 传递 BFS
**题意:**中文题,就是判断一个竞赛图拆成两个图,判断是否都传递
**思路:**分别BFS判深度即可,用这种方法注意要进行读入优化。
/** @Date : 2016-11-18-20.00
* @Author : Lweleth (SoungEarlf@gmail.com)
* @Link : https://github.com/
* @Version :
*/
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <algorithm>
#include <utility>
#include <vector>
#include <map>
#include <set>
#include <string>
#include <stack>
#include <queue>
//#include<bits/stdc++.h>
#define LL long long
#define pii pair<int ,int>
#define mp(x,y) make_pair((x), (y))
#define fi first
#define se second
#define MMF(x) memset((x),0,sizeof(x))
#define MMI(x) memset((x), INF, sizeof(x))
using namespace std;
const int INF = 0x3f3f3f3f;
const int N = 1e5+2000;
vector<int >ed1[2100], ed2[2100];
int vis[2100];
int main()
{
int T;
scanf("%d", &T);
while(T--)
{
int n;
scanf("%d", &n);
for(int i = 1; i <= n; i++)
ed1[i].clear(), ed2[i].clear();
getchar();
for(int i = 1; i <= n; i++)
{
for(int j = 1; j <= n; j++)
{
char t;
t = getchar();//读入优化
if(t == 'P')
ed1[i].push_back(j);
else if(t =='Q')
ed2[i].push_back(j);
}
getchar();
}
int flag = 0;
for(int i = 1; i <= n; i++)
{
queue<int>q;
q.push(i);
MMF(vis);
while(!q.empty())
{
int nw = q.front();
q.pop();
for(int j = 0; j < ed1[nw].size(); j++)
{
int nl = ed1[nw][j];
if(vis[nl] == 0)//第二层的新点,表明第一层不能到达 直接退出
{
vis[nl] = vis[nw] + 1;
if(nw != i || vis[nl] >= 2)
{
flag = 1;
break;
}
q.push(nl);
}
}
if(flag)
break;
}
while(!q.empty())
q.pop();
MMF(vis);
q.push(i);
while(!q.empty())
{
int nw = q.front();
q.pop();
for(int j = 0; j < ed2[nw].size(); j++)
{
int nl = ed2[nw][j];
if(vis[nl] == 0)
{
vis[nl] = vis[nw] + 1;
if(nw != i || vis[nl] >= 2)
{
flag = 1;
break;
}
q.push(nl);
}
}
if(flag)
break;
}
}
if(flag)
puts("N");
else puts("T");
}
return 0;
}
HDU 5961 传递 BFS的更多相关文章
- HDU - 5961 传递  想法,bfs
		
题意:给你一个有向图,满足去掉方向是完全图,将其拆成PQ两个图(没有公共边),问你两图是否分别满足对于任意3个点a,b,c 若有一条边从a到b且有一条边从b到c ,则同样有一条边从a到c. 题解:观察 ...
 - HDU 5961 传递 【图论+拓扑】 (2016年中国大学生程序设计竞赛(合肥))
		
传递 Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem ...
 - HDU 5961 传递 随机化
		
传递 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5961 Description 我们称一个有向图G是传递的,当且仅当对任意三个不同的顶点a,,若 ...
 - HDU 5961 传递
		
http://acm.hdu.edu.cn/showproblem.php?pid=5961 题意: 思路: 话不多说,直接暴力. #include<iostream> #include& ...
 - hdu 5961 传递 (2016ccpc 合肥站 A题)
		
传递 Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submiss ...
 - 【图论】HDU 5961 传递
		
题目内容 题目链接 我们称一个有向图G是传递的当且仅当对任意三个不同的顶点a,若G中有 一条边从a到b且有一条边从b到c ,则G中同样有一条边从a到c. 我们称图G是一个竞赛图,当且仅当它是一个有向图 ...
 - 【HDU 5961 传递】
		
Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submission ...
 - hdu 5961 传递(暴力搜索)
		
我们称一个有向图G是传递的,当且仅当对任意三个不同的顶点a,,若G中有 一条边从a到b且有一条边从b到c ,则G中同样有一条边从a到c. 我们称图G是一个竞赛图,当且仅当它是一个有向图且它的基图是完全 ...
 - HDU 5961 传递 题解
		
题目 我们称一个有向图G是 传递的,当且仅当对任意三个不同的顶点a,,若G中有 一条边从a到b且有一条边从b到c ,则G中同样有一条边从a到c. 我们称图G是一个 竞赛图,当且仅当它是一个有向图且它的 ...
 
随机推荐
- PCB各层介绍及AD软件画PCB时的规则
			
好久没画过板了,最近因为工作关系,硬件软件全部得自己来,不得不重新打开闲置很久的AltiumDesigner.以前做过点乱七八糟的笔记,本来想回头翻看一下,结果哪儿也找不到,估计已经被不小心删掉了. ...
 - 软件工程 作业part1 自我介绍
			
自我介绍 老师您好,我叫宋雨,本科在长春理工大学,专业是计算机科学与技术. 1.回想一下你曾经对计算机专业的畅想:当初你是如何做出选择计算机专业的决定?你认为过去接触的课程是否符合你对计算机专业的期待 ...
 - Daily Scrum 10
			
今天我们小组开会内容分为以下部分: part 1: 经过反复思考,对于上次组会确定的在系统中加入娱乐版块进行了更进一步的商讨; part 2:继续探讨算法实现: part 3:进行明日的任务分配; ◆ ...
 - LintCode-112.删除排序链表中的重复元素
			
删除排序链表中的重复元素 给定一个排序链表,删除所有重复的元素每个元素只留下一个. 样例 给出 1->1->2->null,返回 1->2->null 给出 1-> ...
 - 安装配置erlang_db_driver
			
erlang-db-driver是北京融易通公司开源的一个erlang支持众多数据库的一个驱动类库,据其wiki介绍,其支持MySQL, Oracle, Sybase, DB2 and Informi ...
 - 原生js移动端可拖动进度条插件
			
该插件最初的想法来自网上的一篇文章,直达链接:https://www.cnblogs.com/libin-1/p/6220056.html 笔者因为业务需要寻找到这个插件,然后拿来用之,发现各种不方便 ...
 - 【Docker 命令】- pause/unpause 命令
			
docker pause :暂停容器中所有的进程. docker unpause:恢复容器中所有的进程. 语法 docker pause [OPTIONS] CONTAINER [CONTAINER. ...
 - Python爬虫requests判断请求超时并重新发送请求
			
下面是简单的一个重复请求过程,更高级更简单的请移步本博客: https://www.cnblogs.com/fanjp666888/p/9796943.html 在爬虫的执行当中,总会遇到请求连接 ...
 - 按照list中实体类的某一属性排序
			
传进一个装有实体类的list public void sort(List<MedicalPracticesDetail> mpdList){ Collections.sort(mpdLis ...
 - 【bzoj1370】[Baltic2003]Gang团伙  并查集
			
题目描述 在某城市里住着n个人,任何两个认识的人不是朋友就是敌人,而且满足: 1. 我朋友的朋友是我的朋友: 2. 我敌人的敌人是我的朋友: 所有是朋友的人组成一个团伙.告诉你关于这n个人的m条信息, ...