【bzoj5047】空间传送装置 堆优化Dijkstra
题目描述
输入
输出
样例输入
3 2 1 3
1 1 5 1
2 2 7 1
1 2 1
2 3 2
3 1 1
样例输出
3
6
题解
堆优化Dijkstra
考虑到如果提前到一个点可以等待,因此先到一定不会比后到劣。所以Dijkstra的贪心策略是正确的。
观察每种边通过所需的时间:$(a_i*x+b_i)\mod c_i+d_i$。因此$x$在模$c_i$意义下只有$c_i$种取值。因此可以先预处理出第$i$种道路在模$c_i$等于$j$的时间下所花费的最小时间。通过求后缀最小值维护即可。(由于关系是一个环,因此可以断环倍增以减少代码量)
然后直接跑堆优化Dijkstra即可。
时间复杂度$O(cm+e\log n)$
#include <queue>
#include <cstdio>
#include <cstring>
#include <utility>
#define N 100010
using namespace std;
typedef pair<int , int> pr;
priority_queue<pr> q;
int a[51] , b[51] , c[51] , d[51] , f[51][4010] , head[N] , to[N << 1] , val[N << 1] , next[N << 1] , cnt , dis[N] , vis[N];
inline void add(int x , int y , int z)
{
to[++cnt] = y , val[cnt] = z , next[cnt] = head[x] , head[x] = cnt;
}
int main()
{
int n , m , s , e , i , j , x , y , z;
scanf("%d%d%d%d" , &n , &m , &s , &e);
for(i = 1 ; i <= m ; i ++ )
{
scanf("%d%d%d%d" , &a[i] , &b[i] , &c[i] , &d[i]);
for(j = 0 ; j < c[i] ; j ++ ) f[i][j] = f[i][j + c[i]] = (a[i] * j + b[i]) % c[i] + d[i];
for(j = 2 * c[i] - 2 ; ~j ; j -- ) f[i][j] = min(f[i][j] , f[i][j + 1] + 1);
}
for(i = 1 ; i <= e ; i ++ ) scanf("%d%d%d" , &x , &y , &z) , add(x , y , z);
memset(dis , 0x3f , sizeof(dis));
dis[1] = s , q.push(pr(-s , 1));
while(!q.empty())
{
x = q.top().second , q.pop();
if(vis[x]) continue;
vis[x] = 1;
for(i = head[x] ; i ; i = next[i])
if(dis[to[i]] > dis[x] + f[val[i]][dis[x] % c[val[i]]])
dis[to[i]] = dis[x] + f[val[i]][dis[x] % c[val[i]]] , q.push(pr(-dis[to[i]] , to[i]));
}
for(i = 2 ; i <= n ; i ++ )
{
if(dis[i] != 0x3f3f3f3f) printf("%d\n" , dis[i] - s);
else puts("-1");
}
return 0;
}
【bzoj5047】空间传送装置 堆优化Dijkstra的更多相关文章
- codevs1557 热浪(堆优化dijkstra)
1557 热浪 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description 德克萨斯纯朴的民眾们这个夏 ...
- BZOJ 3040 最短路 (堆优化dijkstra)
这题不是裸的最短路么?但是一看数据范围就傻了.点数10^6,边数10^7.这个spfa就别想了(本来spfa就是相当不靠谱的玩意),看来是要用堆优化dijkstra了.但是,平时写dijkstra时为 ...
- UVA - 11374 - Airport Express(堆优化Dijkstra)
Problem UVA - 11374 - Airport Express Time Limit: 1000 mSec Problem Description In a small city c ...
- BZOJ5415[Noi2018]归程——kruskal重构树+倍增+堆优化dijkstra
题目描述 本题的故事发生在魔力之都,在这里我们将为你介绍一些必要的设定. 魔力之都可以抽象成一个 n 个节点.m 条边的无向连通图(节点的编号从 1 至 n).我们依次用 l,a 描述一条边的长度.海 ...
- 配对堆优化Dijkstra算法小记
关于配对堆的一些小姿势: 1.配对堆是一颗多叉树. 2.包含优先队列的所有功能,可用于优化Dijkstra算法. 3.属于可并堆,因此对于集合合并维护最值的问题很实用. 4.速度快于一般的堆结构(左偏 ...
- POJ 3635 - Full Tank? - [最短路变形][手写二叉堆优化Dijkstra][配对堆优化Dijkstra]
题目链接:http://poj.org/problem?id=3635 题意题解等均参考:POJ 3635 - Full Tank? - [最短路变形][优先队列优化Dijkstra]. 一些口胡: ...
- 【堆优化Dijkstra+字典序最短路方案】HDU1385-Minimum Transport Cost
[题目大意] 给出邻接矩阵以及到达各个点需要付出的代价(起点和终点没有代价),求出从给定起点到终点的最短路,并输出字典序最小的方案. [思路] 在堆优化Dijkstra中,用pre记录前驱.如果新方案 ...
- 【bzoj5197】[CERC2017]Gambling Guide 期望dp+堆优化Dijkstra
题目描述 给定一张n个点,m条双向边的无向图. 你要从1号点走到n号点.当你位于x点时,你需要花1元钱,等概率随机地买到与x相邻的一个点的票,只有通过票才能走到其它点. 每当完成一次交易时,你可以选择 ...
- 堆优化Dijkstra计算最短路+路径计数
今天考试的时候遇到了一道题需要路径计数,然而蒟蒻从来没有做过,所以在考场上真的一脸懵逼.然后出题人NaVi_Awson说明天考试还会卡SPFA,吓得我赶紧又来学一波堆优化的Dijkstra(之前只会S ...
随机推荐
- 《JavaScript高级程序设计第三版》——细碎知识痛点整理(第六章)
面向对象的程序设计 对象是一组没有特定顺序的值6.1.1 属性类型ECMAScript中有两种属性:数据属性和访问器属性.1. 数据属性Configurable 表示能否通过delete删除属性从而重 ...
- 解决 Jsp_Servlet 编码乱码问题
Tomcat8.0以上浏览器请求的数据编码格式(包含): Get请求的时候Tomcat用UTF-8处理 post请求的时候Tomcat用ISO8859-1处理 Tomcat8.0以下浏览器请求的数据编 ...
- JavaEE 面试题总结
一. JDBC 4 1. Java中访问数据库的步骤 4 2. Statement,PreparedStatement,CallableStatement的功能.特点. 4 3. 如何利用JDBC的A ...
- AMD、CMD和CommonJS规范(转)
CommonJS规范 CommonJS是在浏览器环境之外构建JavaScript生态系统为目标产生的项目,比如服务器和桌面环境中.CommonJS规范是为了解决JavaScript的作用域问题而定义 ...
- v-for的简单实现
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Smartforms 设置纸张打印格式
在sap做一个打印报表,要先设置一个纸张打印格式,下面以工厂中常用来打印的针孔纸为例,在sap设置该纸张的打印格式,以用于报表: 1.运行事务代码SPAD:选择工具栏上的[完全管理]按钮——>选 ...
- http2.2配置
http: 超文本传输协议,工作在应用层 CentOS 6程序环境:httpd-2.2 配置文件: /etc/httpd/conf/httpd.conf /etc/httpd/conf.d/*.con ...
- 转:SpringCloud服务注册中心比较:Consul vs Zookeeper vs Etcd vs Eureka
原文链接地址:http://luyiisme.github.io/2017/04/22/spring-cloud-service-discovery-products/ 这里就平时经常用到的服务发现的 ...
- 协程实现tcp两个客户端的通讯
import socket import gevent from gevent import monkey monkey.patch_all() def cb_work(recv_num,send_n ...
- LeetCode978. 最长湍流子数组
问题:978. 最长湍流子数组 当 A 的子数组 A[i], A[i+1], ..., A[j] 满足下列条件时,我们称其为湍流子数组: 若 i <= k < j,当 k 为奇数时, A[ ...