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

前言

这是今天C组的题,闲得无聊做了一会,结果就对了233。这算是学了SPFA之后的第一次实战了。反正其他C组题我也不想做了。好了现在bi~~(系统自动屏蔽)也在做这道题。
还有这道题的名字叫嗯哼

正题

题目

一个有向图,有两个GPS,它们认为每条边的长度不尽相同,如果你走的路有GPS认为这不是最短路,就会报警警告一次,如果两个GPS都认为不是,那就会警告2次,要求警告次数最少。


Input

第一行,整数N 和M。
接下来M 行,第i 行有四个整数Ai,Bi, Pi,Qi 描述第i 条道路。

Output

输出单独一行一个整数——FJ 选择从他家到达农场的最佳线路之后,路上收到的最小总警告数。

Sample Input

5 7
3 4 7 1
1 3 2 20
1 4 17 18
4 5 25 3
1 2 10 1
3 5 4 14
2 4 6 5

Sample Output

1

【样例解释】

输入详述:

这里有5 个路口和7 条有向道路。第一条道路从路口3 到路口4 连接两个路口;第一GPS 认为这条路需要7 单位时间来通过,接着第二GPS 认为它只需1单位时间,诸如此类。

输出详述:

如果FJ 按照路线1->2->4->5 走,那么第一GPS 会在1->2 这条路上发出警告(它认为1->3 这条路更好)。然而,对于路线剩下的2->4->5,两个GPS 都快乐地坐着FJ 的小车通过了,因为每个GPS 都以为这是2 到5 的最短路。


解题思路

首先我们要分别算出2个GPS的每个点到达终点的最小值,然后判断如果前一个点的最短路+两点之间的权值不等于后一个点的最短路,则这个GPS会认为这条路是错的。为了方便我们把有向图倒着存,然后SPFA搜3次。


代码

#include<cstdio>
#include<cstring>
using namespace std;
struct line{int first,last,l1,l2,next;
};//邻接表
line a[50001];
int f[10001],f2[10001],ff[10001],n,m,ls[10001],state[10001],tail,head,p,w;
bool b[10001];
void spfaA()
{memset(f,127/3,sizeof(f));//初始化tail=1;head=0;f[n]=0;state[1]=n;b[n]=true;//初始化do{head=(head+2)%n-1;//循环队列p=ls[state[head]];//找边while (p!=0){if (f[a[p].first]+a[p].l1<f[a[p].last])//松弛{f[a[p].last]=f[a[p].first]+a[p].l1;if (!b[a[p].last]){tail=(tail+2)%n-1;//入队state[tail]=a[p].last;b[a[p].last]=true;}}p=a[p].next;//下一条}b[state[head]]=false;//解封}while (tail!=head);
}
void spfaB()//一样的不解释
{memset(f2,127/3,sizeof(f2));tail=1;head=0;f2[n]=0;state[1]=n;b[n]=true;do{head=(head+2)%n-1;p=ls[state[head]];while (p!=0){if (f2[a[p].first]+a[p].l2<f2[a[p].last]){f2[a[p].last]=f2[a[p].first]+a[p].l2;if (!b[a[p].last]){tail=(tail+2)%n-1;state[tail]=a[p].last;b[a[p].last]=true;}}p=a[p].next;}b[state[head]]=false;}while (tail!=head);
}
int check(int x)//判断该条边会有几个GPS报错
{int s=0;if (f[a[x].first]+a[x].l1!=f[a[x].last]) s++;//第一个GPSif (f2[a[x].first]+a[x].l2!=f2[a[x].last]) s++;//第二个GPSreturn s;//返回
}
void spfa()
{memset(ff,127/3,sizeof(ff));tail=1;head=0;ff[n]=0;state[1]=n;b[n]=true;do{head=(head+2)%n-1;p=ls[state[head]];while (p!=0){w=check(p);//代价if (ff[a[p].first]+w<ff[a[p].last]){ff[a[p].last]=ff[a[p].first]+w;if (!b[a[p].last]){tail=(tail+2)%n-1;state[tail]=a[p].last;b[a[p].last]=true;}}p=a[p].next;}b[state[head]]=false;}while (tail!=head);printf("%d",ff[1]);//输出
}
int main()
{freopen("gpsdual.in","r",stdin);freopen("gpsdual.out","w",stdout);scanf("%d%d",&n,&m);for (int i=1;i<=m;i++){scanf("%d%d%d%d",&a[i].last,&a[i].first,&a[i].l1,&a[i].l2);a[i].next=ls[a[i].first];ls[a[i].first]=i;}   spfaA();spfaB();spfa();
}

好了现在bi~~(系统自动屏蔽)做完了道题。

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

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

相关文章

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;相比去…

深入理解分布式系统中的缓存架构(上)

转载自 深入理解分布式系统中的缓存架构(上) 本文主要介绍大型分布式系统中缓存的相关理论&#xff0c;常见的缓存组件以及应用场景。 1 缓存概述 2 缓存的分类 缓存主要分为以下四类 2.1 CDN缓存 基本介绍 CDN(Content Delivery Network 内容分发网络)的基本原理是广泛…

微软向开发者推出区块链概念验证框架

微软在近期的一篇博文中宣布了一个新的框架&#xff0c;用以在Azure云平台上加速已通过企业概念验证&#xff08;PoC&#xff09;的区块链部署。微软希望用户能在可支持分布式账本&#xff08;DLT&#xff09;解决方案的基础设施上&#xff0c;借助于灵活的契约和更少的时间&am…

Cookie和Session 登录

Cookie 实现免登陆和Session 01、 需求说明 完成用户登录功能 登录成功后跳到成功页面,显示用户名 登录失败可以跳回登录页面 登录成功后后续操作均能显示当前登录的用户名 02、完成代码 DologinServlet.java Override protected void service(HttpServletRequest req, Http…

《给教师的阅读建议》经典语录

System.out.print("今天开始继续读书摘录"); //不知道官方让不让我在博客里面记录 //如果不让的话我可能得转到别的上面记录 System.out.print("现在开始看《给教师的阅读建议》"); System.out.println("今天是第1天&#xff01;也是最后一天");…

教你一招快速打开idea的秘诀

大家根据电脑系统的位数&#xff0c;选择 32 位的 VM 配置文件或者 64 位的 VM 配置文件32 位操作系统内存不会超过 4G&#xff0c;所以没有多大空间可以调整&#xff0c;建议不用调整了64 位操作系统中 8G 内存以下的机子或是静态页面开发者是无需修改的。64 位操作系统且内存…

深入理解分布式系统中的缓存架构(下)

转载自 深入理解分布式系统中的缓存架构(下) 承接上一篇《理解分布式系统中的缓存架构(上)》&#xff0c;介绍了大型分布式系统中缓存的相关理论&#xff0c;常见的缓存组件以及应用场景&#xff0c;本文主要介绍缓存架构设计常见问题以及解决方案&#xff0c;业界案例。 分…

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

前言 懒… 正题 题1&#xff1a;牛车&#xff08;jzoj1390&#xff09; 有m条公路&#xff0c;有n头牛各开一辆车&#xff0c;如果有x辆车开在它前门&#xff0c;它速度就会降低d*x&#xff0c;路上速度至少为l。求有多少头牛可以上路。 输入 第1行: 4个空格隔开的整数N,M,…

JSP的四大作用域和九大内置对象

JSP的四大作用域和九大内置对象 https://wenku.baidu.com/view/a0974190152ded630b1c59eef8c75fbfc77d949d?ivk_sa1023194j&bfetypenew

事件总线知多少(2)

1.引言 之前的一篇文章事件总线知多少&#xff08;1&#xff09;&#xff0c;介绍了什么是事件总线&#xff0c;并通过发布订阅模式一步一步的分析重构&#xff0c;形成了事件总线的Alpha版本&#xff0c;这篇文章也得到了大家的肯定和积极的反馈和建议&#xff0c;在此谢谢大…

记录程序人生2020.8.11

1.晚休的时间总是短暂的&#xff0c;甚至你都没有来得及闭眼呢就需要将它睁开。上眼皮与下眼皮一直恋恋不舍的分开&#xff0c;天花板渐渐的呈现出来&#xff0c;该起了&#xff01; 2.5点一刻准时坐在外面的水泥台阶上&#xff0c;飞速打开屏幕中的背单词软件&#xff0c;%……

DDD理论学习系列(4)-- 领域模型

1.引言 我们还是先来拆词理解&#xff0c;领域模型可以拆为“领域”和“模型”二词。 领域&#xff1a;按照我们之前的文章的理解&#xff0c;DDD中的领域是指软件系统要解决的问题&#xff0c;如我们的办公设备公众号在线商城就是为了解决电商问题&#xff0c;对应的就是电商…

Ajax判断用户名是否可用

Ajax的简介 01展示效果并认识Ajax 方案1&#xff1a;传统方案 提交表单&#xff0c;服务器端处理&#xff0c;错误后跳转到注册页面&#xff0c;同时显示错误信息。返回客户端的是整个注册页面。 缺点&#xff1a;较大的网络流量&#xff0c;用户体验不好 方案2&#xff1a;使…

学习分布式不得不会的ACP理论

转载自 学习分布式不得不会的ACP理论 2000年7月&#xff0c;加州大学伯克利分校的Eric Brewer教授在ACM PODC会议上提出CAP猜想。2年后&#xff0c;麻省理工学院的Seth Gilbert和Nancy Lynch从理论上证明了CAP。之后&#xff0c;CAP理论正式成为分布式计算领域的公认定理。 无…

浅谈我的读书史

点击上方蓝字关注我们本文是【雄雄的小课堂】原创的第 137 篇文章昨日晚间&#xff0c;一个朋友突然问我&#xff1a;“读书真的会有所收获吗&#xff1f;”“读书&#xff0c;真的会改变一个人吗&#xff1f;”刚看到这个问题时&#xff0c;我有点愕然&#xff0c;想着为啥会突…