UVa12661 Funny Car Racing(Dijkstra)

2023-11-05 14:36

本文主要是介绍UVa12661 Funny Car Racing(Dijkstra),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题意

给定n个点,m条边,起始点s,目标点t,求从起点s到终点t的最短距离。已经道路上的边e是每隔 e a e_a ea秒开启,再隔 e b e_b eb秒关闭,通过时间为 e t e_t et

思路

在计算边 e u v e_{uv} euv从u到v的时间时,用 d u d_u du表示到达u时的时间,如果 ( d u m o d ( e a + e b ) ) + e t < e a (d_u \bmod (e_a+e_b)) + e_t < e_a (dumod(ea+eb))+et<ea,则 d v = d u + e t d_v = d_u + e_t dv=du+et,否则 d v = d u − ( d u m o d ( e a + e b ) ) + e a + e b + e t d_v=d_u - (d_u \bmod(e_a+e_b)) + e_a + e_b + e_t dv=du(dumod(ea+eb))+ea+eb+et

代码

#include <bits/stdc++.h>using namespace std;#define _for(i, a, b) for(int i = (a); i < (b); i++)
#define _rep(i, a, b) for (int i = (a); i <= (b); i++)struct Edge
{int from, to, dist, open, close;
};struct HeapNode
{int u, d;bool operator<(const HeapNode& other) const{return d > other.d;}
};template <size_t SZV, int INF>
struct Dijkstra
{int n;bool done[SZV];vector<Edge> edges;vector<int> graph[SZV];int d[SZV];int p[SZV];void init(int n){this-> n = n;_for(i, 0, n) {graph[i].clear();}edges.clear();}void addEdge(int from, int to, int w, int open, int close){graph[from].push_back(static_cast<int>(edges.size()));edges.push_back((Edge){from, to, w, open, close});}void dijkstra(int s){priority_queue<HeapNode> pq;fill_n(done, n, false);fill_n(d, n, INF);d[s] = 0;pq.push({s, 0});while (!pq.empty()) {HeapNode curNode = pq.top();pq.pop();int u = curNode.u;if (done[u]) {continue;}done[u] = true;_for(i, 0, static_cast<int>(graph[u].size())) {Edge& edge = edges[graph[u][i]];int newDist = arrive(d[u], edge);if (newDist < d[edge.to]) {d[edge.to] = newDist;pq.push((HeapNode){edge.to, newDist});}}}}int arrive(int d, const Edge& edge){int k = d % (edge.open + edge.close);if (k + edge.dist <= edge.open) {return d + edge.dist;}return d - k + edge.open + edge.close + edge.dist;}
};void fastio()
{ios_base::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
}const int MAXN = 305;
const int INF = 1e6;static Dijkstra<MAXN, INT_MAX> solver;int main()
{fastio();#ifndef ONLINE_JUDGEifstream fin("f:\\OJ\\uva_in.txt");streambuf* back = cin.rdbuf(fin.rdbuf());#endifint kase = 1;int n, m, s, t;while (cin >> n >> m >> s >> t) {solver.init(n + 1);_for(i, 0, m) {int u, v, a, b, w;cin >> u >> v >> a >> b >> w;if (w > a) {continue;}solver.addEdge(u, v, w, a, b);}solver.dijkstra(s);cout << "Case " << kase++ << ": " << solver.d[t] << endl;}#ifndef ONLINE_JUDGEcin.rdbuf(back);#endifreturn 0;
}

这篇关于UVa12661 Funny Car Racing(Dijkstra)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/350500

相关文章

poj 1502 MPI Maelstrom(单源最短路dijkstra)

题目真是长得头疼,好多生词,给跪。 没啥好说的,英语大水逼。 借助字典尝试翻译了一下,水逼直译求不喷 Description: BIT他们的超级计算机最近交货了。(定语秀了一堆词汇那就省略吧再见) Valentine McKee的研究顾问Jack Swigert,要她来测试一下这个系统。 Valentine告诉Swigert:“因为阿波罗是一个分布式共享内存的机器,所以它的内存访问

uva 10801(乘电梯dijkstra)

题意: 给几个电梯,电梯0 ~ n-1分别可以到达很多层楼。 换乘电梯需要60s时间。 问从0层到target层最小的时间。 解析: 将进入第0层的电梯60s也算上,最后减。 坑点是如果target为0输出0。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algori

hdu 3790 (单源最短路dijkstra)

题意: 每条边都有长度d 和花费p,给你起点s 终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的。 解析: 考察对dijkstra的理解。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstrin

poj 3255 次短路(第k短路) A* + spfa 或 dijkstra

题意: 给一张无向图,求从1到n的次短路。 解析: A* + spfa 或者 dijkstra。 详解见上一题:http://blog.csdn.net/u013508213/article/details/46400189 本题,spfa中,stack超时,queue的效率最高,priority_queue次之。 代码: #include <iostream>#i

nyoj 1037 Postscript of Tian Ji racing

一道卡贪心的题。 也算一道改编题。 此题的解法推荐为二分图的最大匹配。 首先将输入数据转换一下,然后将满足题意的一组牌建立条边,最终边的覆盖数即为 LN 最后可得的分数。 然后求出最大匹配即可。 代码如下: #include<stdio.h>#include<string.h>char card[30][5];char s[5];int map[30][30];

Dijkstra算法总结

1.如何建立图   Graph 一般是adjecent list, class DirectedGraphNode {     int label;     List<DirectedGraphNode> neighbors;     ... } 也可以使用 HashMap 和 HashSet 搭配的方式来存储邻接表 hashmap<Integer, List<Integer

BFS 到 Level Order traverse 到 UnionFind 到 Topological Sort 到 Dijkstra 思路总结

====BFS 找联通量,找component. Number of Islands (BFS, DFS 都可以做) Surrounded Regions 算法是:先收集四个周边的 O,然后用BFS或者DFS向里面扩展,visited记录connect点,最后如果没有被visited到的O,会变成X;T: O(m*n), Space: O(m*n). Is Graph Bipartite (

HDU1874_畅通工程续(Dijkstra最短路)

畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 23022    Accepted Submission(s): 8085 Problem Description 某省自从实行了很多年的畅通工程计划后,终

算法训练营|图论第8天 拓扑排序 dijkstra

题目: 拓扑排序 题目链接: 117. 软件构建 (kamacoder.com) 代码: #include<bits/stdc++.h>#include<unordered_map>using namespace std;int main() {int n, m;cin >> n >> m;vector<int>inDegree(n, 0);unordered_map<int, v

最短路径算法:迪杰克斯拉(Dijkstra)算法(基于贪心思想)【从一个顶点到其余各顶点的最短路径算法,解决的是有权图中最短路径问题】【能得出最短路径的最优解,但由于它遍历计算的节点很多,所以效率低】

Dijkstra算法是典型最短路算法,用于计算一个节点到其他所有节点的最短路径。主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。Dijkstra算法能得出最短路径的最优解,但由于它遍历计算的节点很多,所以效率低。 Viterbi和Dijkstra算法看起来比较像,两者的区别: Dijkstra算法适应范围更广。Viterbi算法用在特殊的有向无环图中,而Dijkstra算法可以用在