链接:https://www.nowcoder.net/acm/contest/76/F
来源:牛客网

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 32768K,其他语言65536K
64bit IO Format: %lld

题目描述

从实验室出来后,你忽然发现你居然把自己的电脑落在了实验室里,但是实验室的老师已经把大门锁上了。更糟的是,你没有那个老师的电话号码。你开始给你知道的所有人打电话,询问他们有没有老师的电话,如果没有,他们也会问自己的同学来询问电话号码。那么,你能联系到老师并且拿到电脑吗。

输入描述:

存在多组测试样例
每组样例的第一行分别是两个整数n(1<n<=50),m(1<m<=2000),n是在题目当中出现的人数,其中你的序号是1号,实验室老师的序号是n。
接下来的m行,每行有两个整数x(1<=x<=n),y(1<=y<=n),代表x有y的电话号码。

输出描述:

对于每组测试样例,如果你最终能联系到老师,输出“Yes”,否则输出“No”。

输入例子:
5 5
1 3
2 3
3 4
2 4
4 5
输出例子:
Yes

-->

示例1

输入

5 5
1 3
2 3
3 4
2 4
4 5

输出

Yes
示例2

输入

4 3
1 2
2 3
4 1

输出

No
思路:题意就是在有向图中判断指定的两点是否连通,下面放上dfs和bfs的代码:
dfs:
#include <iostream>
#include <vector>
#include <cstring>
#include <cstdio>
using namespace std;
vector <int> a[1001]; //用邻接表记录,对于稀疏图,可以节省内存
int visit[1001]; //标记是否访问过
int n;
int flag; void dfs(int i){
if(visit[i]){
return ;
}
visit[i] = 1;
for(int j = 0; j < a[i].size(); j++){ //遍历当前顶点的相邻顶点
if(a[i][j] == n){ //如果他的邻居就是n直接退出,否则继续深搜的他邻居的邻居
flag = 1;
return ;
}
dfs(a[i][j]);
}
} int main(){
int m, x, y;
while(scanf("%d%d", &n, &m) == 2){
flag = 0;
memset(visit, 0, sizeof(visit));
memset(a, 0, sizeof(a));
for(int i = 0; i < m; i++){
scanf("%d%d", &x, &y);
a[x].push_back(y);
}
visit[1] = 1;;
for(int i = 0; i < a[1].size(); i++){ ////遍历当前顶点的相邻顶点
if(a[1][i] == n){
flag = 1;
break;
}
dfs(a[1][i]);
}
if(flag){
printf("Yes\n");
}
else{
printf("No\n");
}
}
return 0;
}

  bfs:

#include <iostream>
#include <queue>
#include <cstring>
#include <cstdio>
using namespace std;
bool map[1001][1001];
bool visit[1001];
bool flag = 0;
int n;
queue <int> myq; int bfs(int i){
if(i == n){
return 1;
}
visit[i] = 1;
myq.push(i);
while(!myq.empty()){
int x = myq.front();
myq.pop();
for(int j = 1; j <= n; j++){
if(map[x][j] && visit[j] == 0){
if(j == n){
return 1;
}
visit[j] = 1;
myq.push(j);
}
}
}
return 0;
} int main(){
int m;
while(scanf("%d%d", &n, &m) == 2){
memset(map, 0, sizeof(map));
memset(visit, 0, sizeof(visit));
int a, b;
for(int i = 0; i < m; i++){
scanf("%d%d", &a, &b);
map[a][b] = 1;
}
int ans = bfs(1);
if(ans == 1){
printf("Yes\n");
}
else{
printf("No\n");
}
} return 0;
}

  

  

15-Call to your teacher(有向图的连通判断)的更多相关文章

  1. HD1269迷宫城堡(有向图 && 划分连通块)

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  2. K - Strange Country II 暴力dfs判断有向图是否连通//lxm

    You want to visit a strange country. There are n cities in the country. Cities are numbered from 1 t ...

  3. LOJ-10106(有向图欧拉回路的判断)

    题目链接:传送门 思路: (1)将每个单词视为有向路径,单词的起始字母是起始节点,末尾字母是终止节点,然后找由字母建立的有向图 是否是欧拉图或者半欧拉图. (2)先用并查集判断是否连通,再判断入度与出 ...

  4. hdu 4738 2013杭州赛区网络赛 桥+重边+连通判断 ***

    题意:有n座岛和m条桥,每条桥上有w个兵守着,现在要派不少于守桥的士兵数的人去炸桥,只能炸一条桥,使得这n座岛不连通,求最少要派多少人去. 处理重边 边在遍历的时候,第一个返回的一定是之前去的边,所以 ...

  5. Expm 9_1 有向图中环的判断问题

    [问题描述] 给定一个有向图,要求使用深度优先搜索策略,判断图中是否存在环. package org.xiu68.exp.exp9; public class Exp9_1 { //用深度优先搜索判断 ...

  6. POJ2186(有向图缩点)

    Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 28379   Accepted: 11488 De ...

  7. 2018年牛客多校寒假 第四场 F (call to your teacher) (图的连通性)

    题目链接 传送门:https://ac.nowcoder.com/acm/contest/76/F 思路: 题目的意思就是判断图的连通性可以用可达性矩阵来求,至于图的存储可以用邻接矩阵来储存,求出来可 ...

  8. PAT 1046 划拳(15)(代码)

    1046 划拳(15)(15 分) 划拳是古老中国酒文化的一个有趣的组成部分.酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字.如果谁比划出的数字正好等于两人喊出的数字之和,谁就赢 ...

  9. 输入一批考生的的准考证号码,如果是 15 位,表示输入正确,否则重新输入。然后判断这个人的考试类别(号码中如果是以奇数结尾则考试类别为“A 类”,否则为“B 类”),最后输出此准考证的前 5 位和后 4 位,其他位用“*”来代替。说明:使用 StringBuffer 类的相关方法完成实验内容。

    因为是一批考生,所以先创建一个字符数组存放一组准考证号. 此外这个程序涉及到包装类与基本数据类型的互相转换. string的substring方法,返回一个字符串是该字符串的子串.从第一个参数开始,第 ...

随机推荐

  1. Makefile编写 四 函数篇

    一.函数的调用语法 函数调用与变量一样,也是以“$”来标识的,其语法如下: $(<function> <arguments>) 或是 ${<function> &l ...

  2. JVM内存管理之GC算法精解(五分钟让你彻底明白标记/清除算法)

    相信不少猿友看到标题就认为LZ是标题党了,不过既然您已经被LZ忽悠进来了,那就好好的享受一顿算法大餐吧.不过LZ丑话说前面哦,这篇文章应该能让各位彻底理解标记/清除算法,不过倘若各位猿友不能在五分钟内 ...

  3. appium+python自动化33-解锁九宫格(TouchAction)

    TouchAction 1.源码可以在这个路径找到:Lib\site-packages\appium\webdriver\common\touch_action.py class TouchActio ...

  4. node+express+socket.io制作一个聊天室功能

    首先是下载包: npm install express npm install socket.io 建立文件: 服务器端代码:server.js var http=require("http ...

  5. 关于mongodb ,redis,memcache之间见不乱理还乱的关系和作用

    先说我自己用的情况: 最先用的memcache ,用于键值对关系的服务器端缓存,用于存储一些常用的不是很大,但需要快速反应的数据 然后,在另一个地方,要用到redis,然后就去研究了下redis. 一 ...

  6. 关于setTimeout的一个逻辑题

    function hh() { for (var i = 1; i <=5; i++) { setTimeout(function(){ console.log(i); },100) } con ...

  7. 22_java之File对象

    01IO技术概述 * A:IO技术概述 * a: Output * 把内存中的数据存储到持久化设备上这个动作称为输出(写)Output操作 * b: Input * 把持久设备上的数据读取到内存中的这 ...

  8. Netty心跳之IdleStateHandler

    Netty提供了对心跳机制的天然支持,心跳可以检测远程端是否存活,或者活跃 今天我们就一起初识一下Netty4的心跳机制 Netty4.0提供了一个类,名为IdleStateHandler,这个类可以 ...

  9. requirejs——config

    config 函数用于requirejs的配置信息.主要包括:baseUrl.paths: 一.baseUrl: 待续

  10. Spring Boot实践——SpringMVC视图解析

    一.注解说明 在spring-boot+spring mvc 的项目中,有些时候我们需要自己配置一些项目的设置,就会涉及到这三个,那么,他们之间有什么关系呢? 首先,@EnableWebMvc=Web ...