题面

一开始拿到这个问题并不好做,于是考虑拆点。

考虑将一个点拆成 \(c+1\) 个,每个点表示(编号,剩余油量)。

然后 \(\text{Dijkstra}\) 最短路即可。

每次跑 \(\text{Dijkstra}\) 时,先判断能不能再加 \(1\) 单位的油,然后遍历每一条出边,加入优先队列。

注意节点编号从 \(0\) 开始。

#include <bits/stdc++.h>
#define DEBUG fprintf(stderr, "Passing [%s] line %d\n", __FUNCTION__, __LINE__)
#define itn int
#define gI gi using namespace std; inline int gi()
{
int f = 1, x = 0; char c = getchar();
while (c < '0' || c > '9') {if (c == '-') f = -1; c = getchar();}
while (c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return f * x;
} const int maxn = 1003, maxm = 10003, maxx = 103; int q, n, m, c, s, e, yj[maxn];
int tot, head[maxn], ver[maxm * 2], nxt[maxm * 2], edge[maxm * 2];
int dist[maxn][maxx];
struct Node
{
int sy, now, y;
bool operator < (const Node &a) const
{
return sy > a.sy;
}
} ; inline void add(int u, int v, int w)
{
ver[++tot] = v, nxt[tot] = head[u], edge[tot] = w, head[u] = tot;
} int vis[maxn][maxx]; inline int Dij(int c, int s, int e)
{
priority_queue <Node> q;
memset(vis, 0, sizeof(vis));
memset(dist, 0x3f, sizeof(dist));
q.push((Node){0, s, 0});
while (!q.empty())
{
Node now = q.top(); q.pop();
if (now.now == e) return now.sy;
if (vis[now.now][now.y]) continue;
vis[now.now][now.y] = 1;
if (now.y < c)
{
if (dist[now.now][now.y + 1] > now.sy + yj[now.now])
{
dist[now.now][now.y + 1] = now.sy + yj[now.now];
q.push((Node){dist[now.now][now.y + 1], now.now, now.y + 1});
}
}
for (int i = head[now.now]; i; i = nxt[i])
{
int v = ver[i], w = edge[i];
if (now.y >= w)
{
if (dist[v][now.y - w] > now.sy)
{
dist[v][now.y - w] = now.sy;
q.push((Node){now.sy, v, now.y - w});
}
}
}
}
return -1;
} int main()
{
//freopen(".in", "r", stdin);
//freopen(".out", "w", stdout);
n = gi(), m = gi();
for (int i = 0; i < n; i+=1) yj[i] = gi();
for (int i = 1; i <= m; i+=1)
{
int u = gi(), v = gi(), w = gi();
add(u, v, w), add(v, u, w);
}
q = gi();
while (q--)
{
c = gi(), s = gi(), e = gi();
int t = Dij(c, s, e);
if (t == -1) puts("impossible");
else printf("%d\n", t);
}
return 0;
}

最新文章

  1. sujection重构
  2. C# 代理/委托 Delegate
  3. Step by Step
  4. CSS布局 ——从display,position, float属性谈起(转)
  5. C#数组反转
  6. (step7.2.4)hdu 2674(N!Again——简单数论)
  7. Apache conf文件配置个人总结
  8. Jenkins - 持续集成环境搭建【转】
  9. 【LeetCode】136. Single Number
  10. Dubbo(一) 开始认识Dubbo,分布式服务框架
  11. windows 10 防火墙设置规则:允许特定ip端口
  12. codeforces8A
  13. c# Winform Chart入门
  14. [Solution] 893. Groups of Special-Equivalent Strings
  15. Linux - 查看和更改系统字符集
  16. 51nod 1295 XOR key 可持久化01字典树
  17. Python多线程与多线程中join()的用法
  18. 如何查看 Ubuntu下已安装包版本号
  19. websocket与canvas[转]
  20. 提高你的Python编码效率的“武林秘籍”

热门文章

  1. python練習
  2. Neo4j入门-开始使用
  3. ROS 环境变量配置
  4. Chrome 插件 postman 可以在线post
  5. Linux环境搭建及基础操作
  6. 必看!macOS进阶不得不知的实用小技巧
  7. ASP.NET Identity登录原理
  8. windows命令提示符常用命令
  9. python3爬取淘宝商品(失效)
  10. python笔记07