题目描述

在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件:

1 .路径上的所有点的出边所指向的点都直接或间接与终点连通。

2 .在满足条件1 的情况下使路径最短。

注意:图G 中可能存在重边和自环,题目保证终点没有出边。

请你输出符合条件的路径的长度。

输入输出格式

输入格式:

输入文件名为road .in。

第一行有两个用一个空格隔开的整数n 和m ,表示图有n 个点和m 条边。

接下来的m 行每行2 个整数x 、y ,之间用一个空格隔开,表示有一条边从点x 指向点y 。

最后一行有两个用一个空格隔开的整数s 、t ,表示起点为s ,终点为t 。

输出格式:

输出文件名为road .out 。

输出只有一行,包含一个整数,表示满足题目᧿述的最短路径的长度。如果这样的路径不存在,输出- 1 。

输入输出样例

输入样例#1:

  1. 3 2
  2. 1 2
  3. 2 1
  4. 1 3
输出样例#1:

  1. -1
输入样例#2:

  1. 6 6
  2. 1 2
  3. 1 3
  4. 2 6
  5. 2 5
  6. 4 5
  7. 3 4
  8. 1 5
输出样例#2:

  1. 3

说明

解释1:

如上图所示,箭头表示有向道路,圆点表示城市。起点1 与终点3 不连通,所以满足题

目᧿述的路径不存在,故输出- 1 。

解释2:

如上图所示,满足条件的路径为1 - >3- >4- >5。注意点2 不能在答案路径中,因为点2连了一条边到点6 ,而点6 不与终点5 连通。

对于30%的数据,0<n≤10,0<m≤20;

对于60%的数据,0<n≤100,0<m≤2000;

对于100%的数据,0<n≤10,000,0<m≤200,000,0<x,y,s,t≤n,x≠t。

【解析】

跑两边bfs。

因为要求从走的这个点相连的点能到达终点,那么也能从终点走到那个点。

所以我们在存边的时候顺便存一个反图。就是原来的道路的方向都是反的。

那样我们从终点开始bfs,能够进入队列中的点都标上标记,表示在反图终点可以到达,那么在正图中,这些点也可以到达终点。

但是还有一个条件,与能到达终点的点相连的点也必须能到达终点。

这样。我们从起点开始,如果扫到的这个点是在之前bfs中做过标记的,说明这个点可以到达终点。我们再扫一下和这个点相连的点是否能到达终点,

如果存在一个点不能到达终点,这么当前这个做了标记的点不能走了。

之前的两个处理,我们已经把能走的点做好了标记,那么我们从起点开始一边bfs,记录路径长度选择最优就可以了。

【代码】

  1. //寻找道路
  2. #<iostream>
  3. #include<cstdio>
  4. #include<vector>
  5. #include<queue>
  6. using namespace std;
  7. #define N 10009
  8. typedef pair<int,int> pii;
  9. vector<int>zmap[N],fmap[N];
  10. queue<int>que;
  11. queue<pair<int,int> >quue;
  12. bool can[N],Go[N],done[N];
  13. int n,m,x,y,st,ed,flag;
  14. void bfs(int x)
  15. {
  16. que.push(x);
  17. can[x]=;
  18. while(que.size())
  19. {
  20. int qq=que.front();
  21. for(int i=;i<fmap[qq].size();i++)
  22. {
  23. int k=fmap[qq][i];
  24. if(!can[k])
  25. {
  26. can[k]=;
  27. que.push(k);
  28. }
  29. }
  30. que.pop();
  31. }
  32. }
  33. void slove()
  34. {
  35. for(int i=;i<=n;i++)
  36. {
  37. flag=;
  38. if(!can[i])continue;
  39. for(int j=;j<zmap[i].size();j++)
  40. {
  41. int k=zmap[i][j];
  42. if(!can[k])
  43. {
  44. flag=;break;
  45. }
  46. }
  47. if(flag)continue;
  48. else
  49. Go[i]=;
  50. }
  51. }
  52. void bfs1()
  53. {
  54. quue.push(make_pair(st,));//
  55. while(quue.size())
  56. {
  57. pii x=quue.front();
  58. for(int i=;i<zmap[x.first].size();i++)
  59. {
  60. int t=zmap[x.first][i];
  61. if(t==ed)
  62. {
  63. printf("%d",x.second+);
  64. }
  65. if(Go[t]&&!done[t])
  66. {
  67. done[t]=;
  68. quue.push(make_pair(t,x.second+));
  69. }
  70. }
  71. quue.pop();
  72. }
  73. }
  74. int main()
  75. {
  76. scanf("%d%d",&n,&m);
  77. for(int i=;i<=m;i++)
  78. {
  79. scanf("%d%d",&x,&y);
  80. zmap[x].push_back(y);
  81. fmap[y].push_back(x);
  82. }
  83. scanf("%d%d",&st,&ed);
  84. bfs(ed);
  85. slove();
  86. if(!Go[st])
  87. {
  88. cout<<-;
  89. return ;
  90. }
  91. bfs1();
  92. return ;
  93. }

noip寻找道路的更多相关文章

  1. Codevs 3731 寻找道路 2014年 NOIP全国联赛提高组

    3731 寻找道路 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找 ...

  2. NOIP2014 寻找道路

    2.寻找道路 (road.cpp/c/pas) [问题描述] 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1.路径上的所有点的出边所指 ...

  3. 洛谷P2296 寻找道路 [拓扑排序,最短路]

    题目传送门 寻找道路 题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点 ...

  4. 【DFS】【图论】NOIP2014寻找道路

    [NOIP2014]寻找道路 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1.路径上的所有点的出边所 ...

  5. 【洛谷P2296】[NOIP2014]寻找道路

    寻找道路 题目链接 这道题非常的水,按照题意, 先反向建边,从终点搜索,标记出可以到达终点的点 然后枚举一遍,判断出符合条件1的点 再从起点搜索一遍就可以了 #include<iostream& ...

  6. 洛谷P2296 寻找道路==codevs3731 寻找道路

    P2296 寻找道路 题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点 ...

  7. 洛谷——P2296 寻找道路

    P2296 寻找道路 题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点 ...

  8. luogu 2296 寻找道路 (搜索)

    luogu 2296 寻找道路 题目链接:https://www.luogu.org/problemnew/show/P2296 从终点bfs或者dfs,找出所有终点能到达的点. 然后再从1到n看一下 ...

  9. 最短路 || UOJ 19 寻找道路

    UOJ j19 寻找道路 在有向图G中,每条边的长度均为 1,现给定起点和终点,请你在图中找一条从起点到终点的最短路径,该路径满足以下条件: 路径上的所有点的出边所指向的点都直接或间接与终点连通. * ...

随机推荐

  1. Apache启动失败(Windows 无法在本地计算机启动Apache2.2)

    该问题产生的原因有很多,这里就说说我遇到的问题: 这个问题是突然遇到的,启动的时候连日志都没有产生,最后是通过window的日志中发现问题所在的,如图所示: 发现是目录错了.其他问题也可以通过该日志找 ...

  2. MySql存储过程及MySql常用流程控制语法

    /* 该代码是创建了一个名叫"p4"的存储过程并设置了s1,s2,s3两个int型一个varchar型参数,还可以是其他数据类型,内部创建了x1,x2两个变量 DELIMITER是 ...

  3. 在安装mysql数据库的过程中,显示msvcp100.dll丢失?则么办?

    方案一:重装操作系统为windows10专业版 方案二:问题: 解答: 报错原因是VC运行库不全或者没有安装导致,百度搜索VC集合下载安装, 链接:https://pan.baidu.com/s/1U ...

  4. OC常用函数及变量

    1.OC常用的的函数及变量 (1)算术函数 [算术函数] 函数名 说明 int rand() 随机数生成.(例)srand(time(nil)); //随机数初期化int val = rand()P; ...

  5. STL中vector怎么实现邻接表

    最近,同期的一位大佬给我出了一道题目,改编自 洛谷 P2783 有机化学之神偶尔会做作弊 这道题好坑啊,普通链表过不了,只能用vector来存边.可能更快一些吧? 所以,我想记录并分享一下vector ...

  6. ThoughtWorks(中国) 程序员读书雷达

    ThoughtWorks(中国)程序员读书雷达 软件业的特点是变化.若要提高软件开发的技能,就必须跟上技术发展的步伐.埋首醉心于项目开发与实战,固然能够锤炼自己的开发技巧,却难免受限于经验与学识.世界 ...

  7. Pinpoint扩展插件实践笔记

    为链路(spanEvent)添加tag 背景 我们可能需要想在代码中写入特定的信息到调用链中,并且希望对里面的特定key做检索 实现思路 创建一个特定的类,只需要一个方法,再对这个类的方法进行增强,这 ...

  8. ubuntu 安装 phpstorm

    phpstorm是用JAVA开发的,所以在安装之前需要先安装jdksudo apt-get install default-jdk从官网上下载phpstorm 的linux版本 http://www. ...

  9. RedisTemplate操作Redis

    RedisTemplate Redis 可以存储键与5种不同数据结构类型之间的映射,这5种数据结构类型分别为String(字符串).List(列表).Set(集合).Hash(散列)和 Zset(有序 ...

  10. mysql innobackupex备份实施

    最近用innobackup进行备份测试,我们只备份一个innodb类型的库,数据大小大概50多G,用innobackupex大概用了5个多小时,但是mysqldump只用了大约2个小时,这让我很费解, ...