题目链接

题目描述

给定n个点,m条无向边,初始状态下手里有s个银币。从u点到v点需要花费a个硬币,b个时间单位。在每个点可以花d个时间单位兑换c个银币,求从起点1到各个点需要的最短时间。

思路

这题很关键的一个突破口是数据范围:50个点,从u到v花费不超过50银币,所以总花费不超过2500.通过一个二维数组dis[ i ][ j ]来表示到达 i 点时还剩下 j 个银币时需要的时间最小值,然后跑一遍最短路,最后遍历一遍就可以输出最小值。
注意银币最大只需要2500,所以输入s的时候记得判断
s = min(s, 2500);

代码

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef pair<int, int> PII;const LL inf = 0x3f3f3f3f3f3f3f3f;
const int N = 55, M = 110;
struct Edge {int to, next;LL a, b;
}e[M * 2];
int head[N], idx;
LL c[N], d[N];
LL dis[N][2510];
int n, m, s;void add(int u, int v, LL a, LL b) {e[++idx].to = v;e[idx].next = head[u];e[idx].a = a;e[idx].b = b;head[u] = idx;
}void spfa() {queue<PII> q;for(int i = 1; i <= n; i++) {for(int j = 0; j <= 2500; j++) {dis[i][j] = inf;}}dis[1][s] = 0;q.push({1, s});while(!q.empty()) {int u = q.front().first, w = q.front().second; q.pop();for(int i = head[u]; i; i = e[i].next) {int v = e[i].to;LL a = e[i].a, b = e[i].b;if(w >= a && dis[v][w - a] > dis[u][w] + b) {dis[v][w - a] = dis[u][w] + b;q.push({v, w - a});}}if(dis[u][min(w + c[u], (LL)2500)] > dis[u][w] + d[u]) {dis[u][min(w + c[u], (LL)2500)] = dis[u][w] + d[u];q.push({u, min(w + c[u], (LL)2500)});}}
}int main() {scanf("%d%d%d", &n, &m, &s);s = min(s, 2500);while(m--) {int u, v;LL a, b;scanf("%d%d%lld%lld", &u, &v, &a, &b);add(u, v, a, b);add(v, u, a, b);}for(int i = 1; i <= n; i++) {scanf("%lld %lld", &c[i], &d[i]);}spfa();for(int i = 2; i <= n; i++) {LL res = inf;for(int j = 0; j <= 2500; j++) res = min(res, dis[i][j]);printf("%lld\n", res);}return 0;
}

AtCoder Beginner Contest 164 E Two Currencies【最短路】相关推荐

  1. AtCoder Beginner Contest 264 G.String Fair(最短路/暴力dp 补写法)

    题目 n(n<=18278)个串,第i个串Ti(Ti为纯小写字母串且长度不超过3), 得分Pi(-1e9<=Pi<=1e9),表示只要子串中出现一次Ti,就会获得Pi的得分 对于你可 ...

  2. AtCoder Beginner Contest 202 D - aab aba baa(组合计数,字典序)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 Problem 有 AAA 和 aaa,BBB 个 bbb ,可以使用这 A+BA+BA+B 个字符任 ...

  3. AtCoder Beginner Contest 197 题解(A ~ F)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 目录 A - Rotate B - Visibility C - ORXOR D - Opposite ...

  4. AtCoder Beginner Contest 198 (A ~ F)题解

    目录 A. Div B. Palindrome with leading zeros C. Compass Walking D. Send More Money E. Unique Color F. ...

  5. AtCoder Beginner Contest 215 G - Colorful Candies 2

    AtCoder Beginner Contest 215 G - Colorful Candies 2 有n个糖果,每个糖果有着一个颜色a[i],每次拿k个糖果期望拿到E(x)个不同颜色的糖果,求出k ...

  6. AtCoder Beginner Contest 215 F - Dist Max 2

    AtCoder Beginner Contest 215 F - Dist Max 2 平面上有一系列的点(xi,yi)(x_i,y_i)(xi​,yi​),定义两点(xi,yi),(xj,yj)(x ...

  7. AtCoder Beginner Contest 215 E - Chain Contestant

    AtCoder Beginner Contest 215 E - Chain Contestant 给出一个只包括A~J的字符串,定义一种子序列为:在这个子序列中,相同的字符必定连续出现,求出这样的子 ...

  8. AtCoder Beginner Contest 204 F Hanjo 2

    AtCoder Beginner Contest 204 F Hanjo 2 H宽,W长的二维平面上,用1 * 1或者2 * 1的地砖来铺,要求铺满,求出方案数. 数据范围H <= 6, W & ...

  9. Caddi Programming Contest 2021(AtCoder Beginner Contest 193) 题解

    Caddi Programming Contest 2021(AtCoder Beginner Contest 193) A - Discount 打折浮点数除即可 B - Play Snuke 枚举 ...

  10. Mynavi Programming Contest 2021(AtCoder Beginner Contest 201)题解

    文章目录 A - Tiny Arithmetic Sequence B - Do you know the second highest mountain? C - Secret Number D - ...

最新文章

  1. linux 软件安装
  2. 改变状态栏的背景色和文字的颜色
  3. C2059 语法错误:“)”
  4. dll oem证书导入工具_恶意代码分析之反射型DLL注入
  5. obj转stl_3D打印,如何编辑STL文件?
  6. 【POJ - 1789】【ZOJ - 2158】【SCU - 1832】Truck History (最小生成树)
  7. DataGridview动态添加列
  8. 【华为云技术分享】物体检测yolo3算法 学习笔记2
  9. 循环队列(java)
  10. ORB-SLAM2 地图加载2
  11. Java基础0309
  12. 惯导系统测试方法及测试系统
  13. 酷狗音乐的临时缓存文件转换为MP3文件,java源码
  14. getbook netty实战_《Netty实战》Netty In Action中文版 第1章 Netty——异步和事件驱动...
  15. 将Table转换成HTML
  16. 韩昊20190919-3 效能分析
  17. 硅基生命之漫谈-1:天马行空
  18. Sex and Gender
  19. 【生信】基因组学相关基础知识2
  20. 银河5 号超级计算机,超级计算器前五名:中国“霸占”第一和第二【图】

热门文章

  1. 多文件自平衡云传输 (五)资源管理中心篇 —————— 开开开山怪
  2. 使用face-api.js人脸识别让照片中的人物自动流汗(自动流汗黄豆/差不多得了)
  3. 通过香港招行一卡通收回PayPal资金
  4. java 集合之HashMap 源码阅读记录
  5. rs485九针头_如何在开放源代码中移动针头
  6. 稀疏矩阵 存储格式 COO CSR DIA ELL HYB
  7. 什么是X11-Forwarding
  8. 【OR】ADMMRisk Parity Portfilio Model
  9. 苹果手机科学计算机怎样调用,iOS上的表达式科学计算器Calculator i++使用说明
  10. 超全,整理了18种常用数据分析模型和方法