【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; “我想静静。”这个句子一般是想表达“我想静一静”的意思。但是我们却把…

Git GitHub Gitee GitLab

Git Git 常用命令 git --version 查看 git 版本 git config --global user.name 用户名 设置用户签名 git config --global user.email 邮箱 设置用户签名 git init 初始化本地库 dellDESKTOP-VSDN0Q2 MINGW64 /d/Git-Space/SH0720 $ git init Initialized empty Git reposi…

《下辈子还教书》经典语录(1)

System.out.print("今天开始继续读书摘录"); //不知道官方让不让我在博客里面记录 //如果不让的话我可能得转到别的上面记录 System.out.print("现在开始看《下辈子还教书》"); System.out.println("今天是第1天&#xff01;");自从语文由文化的…

jzoj1478-堆排序【堆】

题目 一些数&#xff0c;用堆把它们从小到大排好 解题思路 每个堆的开头是最大&#xff08;小&#xff09;的。每次把开头读取出来&#xff0c;然后把a[num]提取上来&#xff0c;然后num减1在把新的a[1]降到合适的位置。 代码 #include<cstdio> using namespace std…

异常体系结构

常见异常 异常体系结构 java.lang.Throwable |-----java.lang.Error:一般不编写针对性的代码进行处理 |-----java.lang.Exception:可以进行异常的处理 |------编译时异常(checked) |-----IOException |-----FileNotFoundException |-----ClassNotFoundException |------运行时…

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

转载自 分布式事务解决方案——柔性事务与服务模式 初识分布式系统 关于分布式一致性的探究 分布式系统的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 开发项目&#…

用户自定义异常类

如何自定义异常类&#xff1f; 继承于现有的异常结构&#xff1a;RuntimeException 、Exception提供全局常量&#xff1a;serialVersionUID提供重载的构造器 package com.atguigu.java2; /** 如何自定义异常类&#xff1f;* 1. 继承于现有的异常结构&#xff1a;RuntimeExcep…

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

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

jzoj1082-合并果子【堆,贪心】

题目 有n堆大小不同的果子堆&#xff0c;每次合并两堆消耗它们两堆的重量之和&#xff0c;求把它们全部合并的最小消耗 输入 输入包括两行&#xff0c;第一行是一个整数n(1<&#xff1d;n<10000)&#xff0c;表示果子的种类数。第二行包含n个整数&#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