POJ 2502 - Subway Dijkstra堆优化试水
做这道题的动机就是想练习一下堆的应用,顺便补一下好久没看的图论算法。
Dijkstra算法概述
//从0出发的单源最短路
dis[][] = {INF}
ReadMap(dis);
for i = 0 -> n - 1
d[i] = dis[0][i]
while u = GetNearest(1 .. n - 1, !been[])
been[u] = 1
for_each edge from u
d[edge.v] = min(d[edge.v], d[u] + dis[u][edge.v])
上述算法遍历所有节点,每次 GetNearest() 循环一次,并遍历了所有边,算法复杂度 O(V2+E) = O(V2)
其中 GetNearest() 总取未去过的点中 d[] 最小的点,可以用小根堆维护 d[] 数组优化。
堆优化算法概述
//从0出发的单源最短路
dis[][] = {INF}
ReadMap(dis);
for i = 0 -> n - 1
d[i] = dis[0][i]
heap = BuildHeap(d[], n - 1)
while u = heap.pop()
been[u] = 1
for_each edge from u
if IsBetterDist()
d[edge.v] = d[u] + dis[u][edge.v]
heap.up(heap.IndexOf(edge.v))
建堆 O(VlogV),n次pop() O(VlogV),遍历边并更新堆 O(ElogV),优化算法复杂度 O(2VlogV+ElogV) = O((V+E)logV)
其他心得
* 几何类最短路一定要判重点
//POJ 2502
//Dijkstra 堆优化试水
//飘忽不定的迷离的数据
//AC 2016-10-17 #define HEAP_OPTIMIZE #include <cstdio>
#include <cstring>
#include <iostream>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#define MAXN (200 + 2) + 10
#define SUB_SPEED (40000.0 / 60.0)
#define WALK_SPEED (10000.0 / 60.0)
#define INF 0x7f7f7f7f
using namespace std; inline double sqr(int x){
return x * x;
} struct point {
int x, y;
point(){}
point(int X, int Y): x(X), y(Y){}
inline double norm(){
return sqrt(sqr(x) + sqr(y));
}
friend point operator - (const point &p1, const point &p2){
return point(p1.x - p2.x, p1.y - p2.y);
}
friend bool operator == (const point &p1, const point &p2){
return (p1.x == p2.x) && (p1.y == p2.y);
}
}pt[MAXN]; int n = 0; int IndexOf(const point &p){
for (int i = 0; i < n; i++){
if (pt[i] == p)
return i;
}
return n;
} double dis[MAXN][MAXN], d[MAXN];
bool been[MAXN]; struct BHeap{
int heap[MAXN], n, index[MAXN];
BHeap(): n(0){}
BHeap(int N): n(0){
for (int i = 1; i <= N; i++)
push(i);
}
void down(int i){
for (int j = 2 * i; j <= n; j <<= 1){
j += j < n && d[heap[j]] > d[heap[j + 1]];
if (d[heap[j]] < d[heap[i]]){
swap(index[heap[i]], index[heap[j]]);
swap(heap[i], heap[j]);
i = j;
}
else break;
}
}
void up(int i){
for (int j = i/2; j > 0; j >>= 1){
if (d[heap[j]] > d[heap[i]]){
swap(index[heap[i]], index[heap[j]]);
swap(heap[i], heap[j]);
i = j;
}
else break;
}
}
void push(int a){
heap[++n] = a;
index[a] = n;
up(n);
}
int pop(){
if (!n) return 0;
swap(index[heap[1]], index[heap[n]]);
swap(heap[1], heap[n--]);
down(1);
return heap[n + 1];
}
}heap; int main(){
freopen("fin.c", "r", stdin);
for (int i = 0; i < MAXN; i++)
for(int j = 0; j < MAXN; j++)
if (i == j) dis[i][j]=0;
else dis[i][j] = INF;
scanf("%d%d%d%d", &pt[0].x, &pt[0].y, &(pt[1].x), &pt[1].y);
n = 2;
dis[0][1] = dis[1][0] = (pt[0] - pt[1]).norm() / WALK_SPEED;
point p;
while (~scanf("%d%d", &p.x, &p.y)){
int iter = IndexOf(p), olditer = - 1;
if (iter == n){
pt[n++] = p;
for (int i = 0; i < n; i++){
dis[i][n - 1] = dis[n - 1][i] = (pt[n - 1] - pt[i]).norm() / WALK_SPEED;
}
}
olditer = iter;
while (scanf("%d%d", &p.x, &p.y), ~p.x && ~p.y){
int iter = IndexOf(p);
if (iter == n){
pt[n++] = p;
for (int i = 0; i < n; i++){
if (i != olditer)
dis[i][n - 1] = dis[n - 1][i] = (pt[n - 1] - pt[i]).norm() / WALK_SPEED;
else
dis[i][n - 1] = dis[n - 1][i] = (pt[n - 1] - pt[i]).norm() / SUB_SPEED;
}
}
else dis[olditer][iter] = dis[iter][olditer] = (pt[iter] - pt[olditer]).norm() / SUB_SPEED;
olditer = iter;
}
}
for (int i = 1; i < n; i++)
d[i] = dis[0][i];
#ifdef HEAP_OPTIMIZE
heap = BHeap(n - 1);
#endif
while (
#ifdef HEAP_OPTIMIZE
int v = heap.pop()
#else
1
#endif
){
#ifndef HEAP_OPTIMIZE
double minn = INF;
int v = - 1;
for (int i = 1; i < n; i ++)
if ((!been[i])&&(d[i] < minn)){
minn = d[i];
v = i;
}
if (!~v) break;
#endif
been[v] = 1;
for (int i = 1; i < n; i++){
if (!been[i]){
if (d[v] + dis[v][i] < d[i]){
d[i] = d[v] + dis[v][i];
#ifdef HEAP_OPTIMIZE
heap.up(heap.index[i]);
#endif
}
}
}
}
printf("%.f\n", d[1]);
}
POJ 2502 - Subway Dijkstra堆优化试水的更多相关文章
- POJ 2502 Subway (Dijkstra 最短+建设规划)
Subway Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6689 Accepted: 2176 Descriptio ...
- Bzoj 2834: 回家的路 dijkstra,堆优化,分层图,最短路
2834: 回家的路 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 62 Solved: 38[Submit][Status][Discuss] D ...
- POJ2387(dijkstra堆优化)
Til the Cows Come Home Bessie is out in the field and wants to get back to the barn to get as much s ...
- POJ 2502 Subway / NBUT 1440 Subway / SCU 2186 Subway(图论,最短距离)
POJ 2502 Subway / NBUT 1440 Subway / SCU 2186 Subway(图论,最短距离) Description You have just moved from a ...
- hdu 2544 单源最短路问题 dijkstra+堆优化模板
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- 深入理解dijkstra+堆优化
深入理解dijkstra+堆优化 其实就这几种代码几种结构,记住了完全就可以举一反三,所以多记多练多优化多思考. Dijkstra 对于一个有向图或无向图,所有边权为正(边用邻接矩阵的形式给出), ...
- dijkstra堆优化(multiset实现->大大减小代码量)
例题: Time Limit: 1 second Memory Limit: 128 MB [问题描述] 在电视时代,没有多少人观看戏剧表演.Malidinesia古董喜剧演员意识到这一事实,他们想宣 ...
- POJ 1511 - Invitation Cards 邻接表 Dijkstra堆优化
昨天的题太水了,堆优化跑的不爽,今天换了一个题,1000000个点,1000000条边= = 试一试邻接表 写的过程中遇到了一些问题,由于习惯于把数据结构封装在 struct 里,结果 int [10 ...
- Dijkstra堆优化学习
最短路径例题 今天特地学习了Dijkstra的堆优化(主要是慕名已久). 我们需要一个堆来记录[编号,到编号这个点的最短路径值(当然只是当前的)] 与原来的Dijkstra操作基本一致,主要有以下几点 ...
随机推荐
- [Codeforces Round #275 (Div. 2)]B - Friends and Presents
最近一直在做 codeforces ,总觉得已经刷不动 BZOJ 了? ——真是弱喵 你看连 Div.2 的 B 题都要谢谢题解,不是闲就是傻 显然我没那么闲 ╮(╯_╰)╭ 我觉得这题的想法挺妙的~ ...
- JSTL中的scope属性
前两天接到老大一个任务:要验证一下<c:import>能否动态地引入不同的文件.当时很兴奋,要知道在对日外包里面,这个也得算技术活了.呵呵! 说干就干,写了两个jsp文件:m.jsp t ...
- [转]SQLServer2008日志文件无法收缩处理方法
问题描述 发现有的数据库日志文件太大,无论如何收缩执行几次SQL语句都不行.事务日志达30+G,而且使用常规的截断.收缩方法均无法减小日志物理文件的尺寸,经过一番寻找,终于找到了解决方法. 查 ...
- jQuery:获取浏览器中的分辨率
JQuery: <script type="text/javascript"> $(document).ready(function(){ alert($(window ...
- filter and listener
Java Servlet 是运行在 Web 服务器或应用服务器上的程序,它是作为来自 Web 浏览器或其他 HTTP 客户端的请求和 HTTP 服务器上的数据库或应用程序之间的中间层. 使用 Serv ...
- 【支付专区】之对字符串数据进行Base64位加密,解密
加密,解密 String pwd="测试"; byte[] bytes = pwd.getBytes("UTF-8"); //加密 String pwdNew= ...
- [内核]Takslet和Workqueue的应用场景
转自:http://blog.chinaunix.net/uid-20382483-id-4077101.html tasklet Workqueue 处于atomic context,不能sleep ...
- codeforces 356 C. Compartments 构造 贪心
一辆车,有n个车厢,每个车厢刚好有4个人 车上有n个学生,第i个车厢有a[i]个学生 如果一个车厢里面的学生数 <= 2,这个车厢里的学生会不开心 如果一个车厢里面的学生数 > 2,这个车 ...
- 虚拟机Ubuntu16,caffe环境搭建
虚拟机下的Ubuntu16.04+caffe+onlycup 官网的step很重要,要跟着官网,的步骤来:http://caffe.berkeleyvision.org/installation.ht ...
- FreeBSD 10 中文环境
中文字体位置 FontPath "/usr/local/lib/X11/fonts/misc/:unscaled" FontPath "/us ...