题目来源:洛谷P2296

思路

一开始看还以为是一道水题 虽然本来就挺水的

本道题的难点在于如何判断是否路径上的点都会直接或者间接连着终点

我们需要在一开始多建一个反向图

然后从终点DFS回去 把路径上的点标记

DFS完之后遍历所有的点 如果当前点没有被标记 说明其不会直接或者间接连着终点

那么我们只需要把没有被标记的点在反向图中到达的点(也就是正向图中到达这个点的前一个点)标记为不计算在图内

PS:这里的标记数组要另外再建一个 如果直接改前面的数组会因为没有更新完就修改而多删除有用的点

这样我们就把所有的不需要遍历的点删除了

最后就是SPFA解决

代码

  1. #include<iostream>
  2. #include<queue>
  3. using namespace std;
  4. #define maxn 100010
  5. queue <int> q;
  6. int n,m,cnt2,cnt1,t,w,start,end;
  7. int h1[maxn],h2[maxn],dis[maxn];
  8. bool f[maxn],vis[maxn],vis1[maxn];//f为spfa的判断 vis为反向图的判断 vis1删除点的判断
  9. struct Edge
  10. {
  11. int to;
  12. int next;
  13. }e1[maxn*],e2[maxn*];
  14. void add1(int u,int v)
  15. {
  16. e1[++cnt1].to=v;
  17. e1[cnt1].next=h1[u];
  18. h1[u]=cnt1;
  19. }
  20. void add2(int u,int v)
  21. {
  22. e2[++cnt2].to=v;
  23. e2[cnt2].next=h2[u];
  24. h2[u]=cnt2;
  25. }
  26. void dfs(int u)
  27. {
  28. vis[u]=;
  29. for(int i=h2[u];i;i=e2[i].next)
  30. {
  31. int v=e2[i].to;
  32. if(!vis[v]) dfs(v);
  33. }
  34. }
  35. void spfa()//常规spfa
  36. {
  37. for(int i=;i<=n;i++) dis[i]=1e9+;
  38. q.push(start);
  39. f[start]=;
  40. dis[start]=;
  41. while(!q.empty())
  42. {
  43. int temp=q.front();
  44. q.pop();
  45. f[temp]=;
  46. if(!vis[temp]) continue;
  47. for(int i=h1[temp];i;i=e1[i].next)
  48. {
  49. int v=e1[i].to;
  50. if(dis[v]>dis[temp]+)
  51. {
  52. dis[v]=dis[temp]+;
  53. if(!f[v])
  54. {
  55. f[v]=;
  56. q.push(v);
  57. }
  58. }
  59. }
  60. }
  61. }
  62. int main()
  63. {
  64. cin>>n>>m;
  65. for(int i=;i<=m;i++)
  66. {
  67. int x,y;
  68. cin>>x>>y;
  69. add1(x,y);//正向图
  70. add2(y,x);//反向图
  71. }
  72. cin>>start>>end;
  73. dfs(end);//从终点DFS
  74. for(int i=;i<=n;i++)//把不用的点删去
  75. {
  76. if(!vis[i])
  77. for(int j=h2[i];j;j=e2[j].next)
  78. {
  79. int v=e2[j].to;
  80. vis1[v]=;//更改新建的数组
  81. }
  82. }
  83. for(int i=;i<=n;i++)
  84. if(vis1[i]==) vis[i]=;//更改不用遍历的点
  85. spfa();
  86. if(dis[end]==1e9+)
  87. cout<<-;
  88. else
  89. cout<<dis[end];
  90. }

【题解】洛谷P2296 [NOIP2014TG] 寻找道路(SPFA+DFS)的更多相关文章

  1. [洛谷P2296] NOIP2014 寻找道路

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

  2. 洛谷 P2296 【寻找道路】

    这道题真的很女少啊 言归正传: 这道题其实就是考验的思路,读题后,我们发现对于某个点他所连接的点必须连接终点,那么我们直接反向存图,从终点进行bfs,可以找到未连接的点,然后对这些点所连接的点进行标记 ...

  3. 【洛谷P2296】寻找道路

    反正图两边bfs #include<iostream> #include<cstdio> #include<queue> using namespace std; ...

  4. 洛谷P1462 通往奥格瑞玛的道路(SPFA+二分答案)

    题目背景 在艾泽拉斯大陆上有一位名叫歪嘴哦的神奇术士,他是部落的中坚力量 有一天他醒来后发现自己居然到了联盟的主城暴风城 在被众多联盟的士兵攻击后,他决定逃回自己的家乡奥格瑞玛 题目描述 在艾泽拉斯, ...

  5. 题解 洛谷 P3639 【[APIO2013]道路费用 】

    不难想到可以\(2^k\)去枚举\(k\)条新边的选择方案,然后加入原图中的边来使图连通,用当前方案的收益去更新答案,但是这样复杂度过不去. 可以先把\(k\)条新边都连上,然后再加入边权从小到大排序 ...

  6. 洛谷 题解 P2296 【寻找道路】

    Problem P2296 [寻找道路] solution 首先声明,这题我用了spfa,而: 关于spfa:它死了. 杀手: NOI 2018−T1 出题人 感谢出题人,没有卡spfa 用时: 20 ...

  7. 洛谷P1462 通往奥格瑞玛的道路(二分+spfa,二分+Dijkstra)

    洛谷P1462 通往奥格瑞玛的道路 二分费用. 用血量花费建图,用单源最短路判断 \(1\) 到 \(n\) 的最短路花费是否小于 \(b\) .二分时需要不断记录合法的 \(mid\) 值. 这里建 ...

  8. 洛谷P1462-通往奥格瑞玛的道路-二分+最短路

    洛谷P1462-通往奥格瑞玛的道路 题目描述 在艾泽拉斯,有\(n\)个城市.编号为\(1,2,3,...,n\). 城市之间有\(m\)条双向的公路,连接着两个城市,从某个城市到另一个城市,会遭到联 ...

  9. DP【洛谷P1704】 寻找最优美做题曲线

    [洛谷P1704] 寻找最优美做题曲线 题目背景 nodgd是一个喜欢写程序的同学,前不久(好像还是有点久了)洛谷OJ横空出世,nodgd同学当然第一时间来到洛谷OJ刷题.于是发生了一系列有趣的事情, ...

随机推荐

  1. java 错误: 未报告的异常错误Exception; 必须对其进行捕获或声明以便抛出

    import java.io.FileInputStream; import java.util.Properties; import java.sql.Connection; import java ...

  2. JavaEE之动态页面技术(JSP/EL/JSTL)

    动态页面技术(JSP/EL/JSTL) JSP技术 jsp脚本和注释 jsp脚本: 1)<%java代码%> ----- 内部的java代码翻译到service方法的内部 2)<%= ...

  3. centos yum安装常用命令

    安装killall命令 yum install -y psmisc 安装sz(下载)和rz(上传)命令 yum install -y lrzsz 安装 ifconfig 命令 yum install ...

  4. 复活hexo静态博客的方法

    我的个人博客http://webhmy.com/是通过hexo搭建的,它支持图片显示,支持md,无需主机空间,可以满足我的大部分需求.但是在2年的使用的过程中遇到一些问题,这里记录下来.便于下次快速复 ...

  5. mui.ajax()和asp.net sql服务器数据交互【2】json数组和封装

    今天没有做循环创建显示:可以参考张鑫旭的文章:<基于HTML模板和JSON数据的JavaScript交互> 1.ashx页面代码 //下面的封装一般框架底层都是写好的:连接 数据库和获取D ...

  6. Linux基础之-Bash命令优先级

    一. Bash简介 命令解释器,也就是 Bourne Again Shell,起源于shell.shell俗称壳,它是指UNIX系统下的一个命令解析器:主要用于用户和系统的交互.UNIX系统上有很多种 ...

  7. Infor SyteLine如何快速锁定用户

    使用Infor Syteline ERP系统,当需要做系统维护时,我们需要通知所有用户退出系统,在维护期间,严禁用户登录,这样的话,我们需要锁定用户.对于这个问题,很多管理员会打开SL的Users窗口 ...

  8. Java 多线程使用

    工作中遇到的问题,记录下解决的思路 问题: 对磁盘进行碎片化测试(比如说,磁盘空间是16G),从64K开始写文件,写满后删除一半,然后写32K 的数据,写满后删除一半...直到4K写满删除一般算是结束 ...

  9. 基于Vue的WebApp项目开发(二)

    利用webpack解析和打包.vue组件页面 相关知识: vue项目中的每个页面其实都是一个.vue的文件,这种文件,Vue称之为组件页面,必须借助于webpack的vue-loader才能运行,所以 ...

  10. idea maven打不了war包

    开发的时候打不了war包,原因是 web.xml有问题或者是在idea里面webroot没有作为web引用, 添加之后WebRoot上面有个地球标志 就ok了