15-Call to your teacher(有向图的连通判断)
链接:https://www.nowcoder.net/acm/contest/76/F
来源:牛客网
空间限制: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
-->
输入
5 5
1 3
2 3
3 4
2 4
4 5
输出
Yes
输入
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(有向图的连通判断)的更多相关文章
- HD1269迷宫城堡(有向图 && 划分连通块)
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- 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 ...
- LOJ-10106(有向图欧拉回路的判断)
题目链接:传送门 思路: (1)将每个单词视为有向路径,单词的起始字母是起始节点,末尾字母是终止节点,然后找由字母建立的有向图 是否是欧拉图或者半欧拉图. (2)先用并查集判断是否连通,再判断入度与出 ...
- hdu 4738 2013杭州赛区网络赛 桥+重边+连通判断 ***
题意:有n座岛和m条桥,每条桥上有w个兵守着,现在要派不少于守桥的士兵数的人去炸桥,只能炸一条桥,使得这n座岛不连通,求最少要派多少人去. 处理重边 边在遍历的时候,第一个返回的一定是之前去的边,所以 ...
- Expm 9_1 有向图中环的判断问题
[问题描述] 给定一个有向图,要求使用深度优先搜索策略,判断图中是否存在环. package org.xiu68.exp.exp9; public class Exp9_1 { //用深度优先搜索判断 ...
- POJ2186(有向图缩点)
Popular Cows Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 28379 Accepted: 11488 De ...
- 2018年牛客多校寒假 第四场 F (call to your teacher) (图的连通性)
题目链接 传送门:https://ac.nowcoder.com/acm/contest/76/F 思路: 题目的意思就是判断图的连通性可以用可达性矩阵来求,至于图的存储可以用邻接矩阵来储存,求出来可 ...
- PAT 1046 划拳(15)(代码)
1046 划拳(15)(15 分) 划拳是古老中国酒文化的一个有趣的组成部分.酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字.如果谁比划出的数字正好等于两人喊出的数字之和,谁就赢 ...
- 输入一批考生的的准考证号码,如果是 15 位,表示输入正确,否则重新输入。然后判断这个人的考试类别(号码中如果是以奇数结尾则考试类别为“A 类”,否则为“B 类”),最后输出此准考证的前 5 位和后 4 位,其他位用“*”来代替。说明:使用 StringBuffer 类的相关方法完成实验内容。
因为是一批考生,所以先创建一个字符数组存放一组准考证号. 此外这个程序涉及到包装类与基本数据类型的互相转换. string的substring方法,返回一个字符串是该字符串的子串.从第一个参数开始,第 ...
随机推荐
- C#开机启动与退出程序
最新用到的项目中需要使用开机自启和退出程序,于是需要 http://www.cnblogs.com/Gaoswatou/p/6605760.html C# WinForm程序退出的方法 1.this. ...
- 打包python文件,让文件程序化
通过对源文件打包,Python程序可以在没有安装 Python的环境中运行,也可以作为一个独立文件方便传递和管理. 现在网上主流的打包方式有两种py2exe或者pyinstaller两款多平台的Pyt ...
- 黄聪:如何使用Add-on SDK开发一个自己的火狐扩展
火狐开放了扩展的开发权限给程序员们,相信很多人都会希望自己做一些扩展来方便一些使用. 我最近做一些项目也需要开发一个火狐扩展,方便收集自己需要的数据,因此研究了几天怎么开发,现在已经差不多完成了,就顺 ...
- jmeter数据关联_后置处理器_正则表达式提取器
- 关于adb devices连不上手机的几种情况
启动adb 1.打开cmd首次使用adb devices,出现下面这两句,就是正在启动adb服务 C:\Users\admin>adb devices List of devices attac ...
- Struts2的fliter与interceptor
struts2 fliter与interceptor的区别 1.拦截器是基于java反射机制的,而过滤器是基于函数回调的.2.过滤器依赖于servlet容器,而拦截器不依赖于servlet容器.3 ...
- 编译hostapd时,出现错误:/usr/bin/ld: cannot find -lnl
book@ubuntu:/work/project/wifi/04.hostapd/hostapd-2.0/hostapd$ make /usr/bin/ld: cannot find -lnl co ...
- ListView下拉刷新,上拉自动加载更多
下拉刷新,Android中非常普遍的功能.为了方便便重写的ListView来实现下拉刷新,同时添加了上拉自动加载更多的功能.设计最初是参考开源中国的Android客户端源码.先看示例图. ...
- Centos7 / RHEL 7 双网卡绑定
http://www.cnblogs.com/hukey/p/6224969.html 1. 简要 双网卡绑定技术在centos7中使用了teaming技术,而在rhel6/centos7中使用 ...
- Rhythmk 一步一步学 JAVA (12) Spring-1 之入门
(一)简单对象Spring XML配置说明 使用Spring (Spring 3.0) 实现最简单的类映射以及引用,属性赋值: 1.1.新建类UserModel: package com.sprin ...