洛谷P2296-寻找道路【日常图论,最短路,SPFA】

题目

一个有向图,要求满足要求的最短路径,要求为:

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

输入1

3 2 (3个点,2条边)
1 2 (1和2之间可以连接)
2 1
1 3 (从1到3)

输出1

-1
这里写图片描述

输入2

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

输出2

3
这里写图片描述


解题思路

其实我们就求出满足要求的点,然后在这些点里找最短路,还有本人这里的方法比较复杂和麻烦


代码

#include<cstdio>
using namespace std;
struct woc{int next,x,y;
};//日常邻接表
woc a[200001],lt[200001];
int xx,yy,n,m,k,state[10001],ls[10001],t,head,tail,f[10001],star,over;
int fls[10001];
bool ltfl[10001];
bool v[10001];
void check()//求所有可以直接或间接到终点的边
{int t=0;int head=0;int tail=1;state[1]=over;ltfl[state[1]]=true;//初始化while (head!=tail){head++;head=(head-1)%n+1;t=fls[state[head]];//求边while (t!=0){if (!ltfl[lt[t].y]){tail++;tail=(tail-1)%n+1;state[tail]=lt[t].y;ltfl[lt[t].y]=true;//标记}t=lt[t].next;//求下一条边}}
}
bool ok(int x)//是否满足要求
{int t=ls[x];while (t!=0){if (!ltfl[a[t].y]) return false;t=a[t].next;}return true;
}
int main()
{scanf("%d%d",&n,&m);state[1]=1;int u=0;    for (int i=1;i<=m;i++){scanf("%d",&xx);scanf("%d",&yy);a[++u].next=ls[xx];ls[xx]=u;a[u].x=xx;a[u].y=yy;//边lt[u].next=fls[yy];fls[yy]=u;lt[u].y=xx;lt[u].x=yy;//记录一条回去的边}   scanf("%d%d",&star,&over);for (int i=1;i<=n;i++) f[i]=2147483647;//初始化    check();//求所有可以直接或间接到终点的边head=0;tail=1;state[1]=star;v[state[1]]=true;f[star]=0;//初始化×2while (head!=tail){head++;//出队head=(head-1)%n+1;//循环队列t=ls[state[head]];while (t!=0){if (f[a[t].x]+1<f[a[t].y] && ok(a[t].y))//判断是否满足要求{f[a[t].y]=f[a[t].x]+1;//松弛if (!v[a[t].y]){tail++;//入队tail=(tail-1)%n+1;//循环队列state[tail]=a[t].y;v[a[t].y]=true;}}t=a[t].next;//下一条边}v[state[head]]=false;//解封}if (f[over]==2147483647) printf("-1");//是否有解else printf("%d\n",f[over]);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/324898.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

活动 | Unity带你亲临王者荣耀KPL总决赛,领略电竞的魅力

《王者荣耀》是由腾讯出品的 Made with Unity的现象级游戏。在Unite Shanghai 2017中的案例专场&#xff0c;我们也曾邀请了《王者荣耀》项目组的技术总监邓君&#xff0c;分享过《王者技术修炼之路》。 从移动游戏到电子竞技&#xff0c;KPL(King Pro League)也是《王者荣耀》…

Java的并发编程中的多线程问题到底是怎么回事儿?

转载自 Java的并发编程中的多线程问题到底是怎么回事儿&#xff1f; 在我之前的一篇《再有人问你Java内存模型是什么&#xff0c;就把这篇文章发给他。》文章中&#xff0c;介绍了Java内存模型&#xff0c;通过这篇文章&#xff0c;大家应该都知道了Java内存模型的概念以及作…

DDD理论学习系列(2)-- 领域

1. 引言 领域一词&#xff0c;主要有以下两个意思&#xff1a; 一国主权所达之地。学术思想或社会活动的范围。 不管是指国家的主权范围也好还是学术活动范围&#xff0c;都是在讲一个范围&#xff0c;一个界限。比如我们常说的&#xff0c;学术领域、思想领域、技术领域、语…

最全、最详细的配置jdk十步法!

求关注求转发大家好&#xff0c;我是雄雄。今天给大家分享的是 如何配置jdk &#xff0c;还记得我当年刚开始自学编程时&#xff0c;jdk配置了好几天才配置好&#xff0c;说来也是惭愧啊。并且配置成功的步骤我自己都不知道是啥&#xff0c;因为当时是东找一个方法&#xff0c;…

RabbitMQ系列教程之三:发布\/订阅(Publish\/Subscribe)

在前一个教程中&#xff0c;我们创建了一个工作队列。工作队列背后的假设是每个任务会被交付给一个【工人】。在这一部分我们将做一些完全不同的事情--我们将向多个【消费者】传递信息。这种模式被称为“发布/订阅”。 为了说明这种模式&#xff0c;我们将构建一个简单的日志…

路径使用场景

路径的使用场景 路径适用的范围&#xff1a;jsp页面中link script img a form 等 如果访问的是其他服务器中的项目文件只可以使用绝对路径 如果访问的是同一个服务器中的其他项目推荐使用根路径 如果访问的是同一个服务器中的同一个项目中的文件推荐使用相对base标签的路径 修改…

【jzoj】2018.1.30NOIP普及组——模拟赛D组

_ 前言 写博客时间 2018/1/30 22:36。 感想&#xff1a;出数据的dalao我服&#xff01; 正题 题目1&#xff1a;二项式展开式&#xff08;jzoj2254&#xff09; 输入一个整数&#xff0c;求展开(ab)^n。展开方式为 (ab)^n?a^n?a^(n-1)b?a^(n-2)b^2…?b^n 其中” ? “…

开发人员也要懂点的测试知识

转载自 开发人员也要懂点的测试知识 本文来自于作者投稿&#xff0c;作者陈彩华&#xff0c;贝聊后端开发工程师。 最近参加了保利威测试总监李乐的《互联网测试姿势》为主题的分享交流会&#xff0c;收获颇丰&#xff0c;作为一个开放&#xff0c;秉承“不懂产品和测试的开…

转发和重定向

需求说明 用户输入并提交登录信息 登录成功&#xff0c;跳转到success.jsp页面 登录失败&#xff0c;跳转回login.jsp页面 理解图 区别详解

实现自己的.NET Core配置Provider之Yaml

YAML是一种更适合人阅读的文件格式&#xff0c;很多大型的项目像Ruby on Rails都选择YAML作为配置文件的格式。如果项目的配置很少&#xff0c;用JSON或YAML没有多大差别。看看rails项目中的配置文件&#xff0c;如果用JSON写试试什么感受吧。 在《实现自己的.NET Core配置Pro…

信息时代与人工智能时代的教育变革

求关注求转发本文是雄雄的小课堂投稿的第 1 篇文章&#xff0c;作者&#xff1a;小溪时代发展迅速&#xff0c;学校的教育体系却没有很大的改变。比如现在的学生们还是学着几百年前的东西。试想一下&#xff0c;这是否真的适合我们这个时代&#xff0c;亦或真的需要改变了。教育…

【jzoj】2018.1.31 NOIP普及组——D组模拟赛

前言 今天题目比较水and我进了C组&#xff0c;不过太太太太太太太太太太太太太太太太绝望了QAQ。所以我也没有做C组的题。写完博客我就做O(∩_∩)O。 正题 题1&#xff1a;奇数统计&#xff08;jzoj1547&#xff09; 就是输入n个数&#xff0c;输出出现次数为奇数的一个数&a…

RabbitMQ系列教程之四:路由(Routing)

在上一个教程中&#xff0c;我们构建了一个简单的日志系统&#xff0c;我们能够向许多消息接受者广播发送日志消息。在本教程中&#xff0c;我们将为其添加一项功能 &#xff0c;这个功能是我们将只订阅消息的一个子集成为可能。 例如&#xff0c;我们可以只将关键的错误消息输…

【jzoj3734,Usaco2014Open银组】双导航(gpsdual)

前言 这是今天C组的题&#xff0c;闲得无聊做了一会&#xff0c;结果就对了233。这算是学了SPFA之后的第一次实战了。反正其他C组题我也不想做了。好了现在bi~~&#xff08;系统自动屏蔽&#xff09;也在做这道题。 还有这道题的名字叫 正题 题目 一个有向图&#xff0c;有…

Java代码到底是如何编译成机器指令的。

转载自 Java代码到底是如何编译成机器指令的。 在《Java代码的编译与反编译》中&#xff0c;有过关于Java语言的编译和反编译的介绍。我们可以通过javac命令将Java程序的源代码编译成Java字节码&#xff0c;即我们常说的class文件。这是我们通常意义上理解的编译。 但是&am…

DDD理论学习系列(3)-- 限界上下文

1. 引言 限界上下文可以拆分为两个词&#xff0c;限界和上下文。限界&#xff1a;是指一个界限&#xff0c;具体的某一个范围。上下文&#xff1a;个人理解就是语境。 比如我们常说的段子&#xff1a; “我想静静。”这个句子一般是想表达“我想静一静”的意思。但是我们却把…

分布式事务解决方案——柔性事务与服务模式

转载自 分布式事务解决方案——柔性事务与服务模式 初识分布式系统 关于分布式一致性的探究 分布式系统的CAP理论&#xff08;需要到博客中查看&#xff09; 分布式系统的BASE理论&#xff08;需要到博客中查看&#xff09; Java中的事务——JDBC事务和JTA事务 Java中的…

“温室里的花朵”也要直面困难

求关注求转发本文是雄雄的小课堂投稿的第 2 篇文章&#xff0c;作者&#xff1a;小溪“花朵”在爸妈的细心培育下成长。可它们不知道未来是怎样的&#xff0c;它们对未来充满着想象与渴望&#xff0c;却没有人曾告诉它们&#xff0c;这个世界布满荆棘&#xff0c;而“花朵们”也…

Visual Studio 2015和2017里面应该创建哪种 Class Library

微软有些时候是一副不讲道理的大家长作风。一个例子就是它在 Visual Studio 2015/2017 里面配置了一大堆普通人没法理解的 Class Library 模板。 你真的知道应该选哪个吗&#xff1f; 这就是 VS2017 里面你可能熟悉的长列表&#xff08;而且因为我没有安装 UWP 开发项目&#…

win10操作技巧介绍,很实用!

求关注求转发本文是雄【雄的小课堂】原创的第 136 篇文章1.wind:返回桌面不管你当前所在的什么窗口&#xff0c;一键即可切换到桌面&#xff0c;有时候称之为“老板键”2.wine:打开计算机我最喜欢用了&#xff0c;不管你在任何窗口&#xff0c;一键打开计算机&#xff0c;相比去…