hdu 1874 dijkstra 队列实现 比数组高效特别在稀疏图
参考 http://blog.csdn.net/zhuyingqingfen/article/details/6370561
刘汝佳白皮书
#include<stdio.h>
#include<queue>
#include<iostream>
#include<vector>
using namespace std;
#define N 2100
#define inf 1000000000
int n,m;
struct node {
int u,v,w,next;
}bian[N];
int yong,head[N];
void creat(int u,int v,int w) {
bian[yong].u=u;
bian[yong].v=v;
bian[yong].w=w;
bian[yong].next=head[u];
head[u]=yong++;
}
void Dcreat(int u,int v,int w) {
creat(u,v,w);
creat(v,u,w);
}
int dijkstra(int u,int end) {
int dis[N],i,j,visit[N];
memset(visit,0,sizeof(visit));
for(i=0;i<n;i++)
dis[i]=inf;
dis[u]=0;
typedef pair<int ,int >p;//pair 定义了自己的排序规则--先比较第一维,相等才比较第二维
priority_queue<p,vector<p>,greater<p> >q;
q.push(make_pair(dis[u],u));
while(!q.empty()) {
p cur=q.top();
j=cur.second;
q.pop();
if(visit[j])continue;
visit[j]=1;
for(i=head[j];i!=-1;i=bian[i].next)
if(dis[bian[i].v]>dis[j]+bian[i].w) {
dis[bian[i].v]=dis[j]+bian[i].w;
q.push(make_pair(dis[bian[i].v],bian[i].v));
}
}
if(dis[end]<inf)
return dis[end];
return -1;
}
int main() {
int i,j,a,b;
while(scanf("%d%d",&n,&m)!=EOF) {
yong=0;
memset(head,-1,sizeof(head));
while(m--) {
scanf("%d%d%d",&a,&b,&j);
Dcreat(a,b,j);
}
scanf("%d%d",&a,&b);
printf("%d\n",dijkstra(a,b));
}
return 0;
}
//定义结构体优先队列
#include<stdio.h>
#include<queue>
#include<iostream>
#include<vector>
using namespace std;
#define N 2100
#define inf 1000000000
int n,m;
struct node {
int u,v,w,next;
}bian[N];
int yong,head[N];
void creat(int u,int v,int w) {
bian[yong].u=u;
bian[yong].v=v;
bian[yong].w=w;
bian[yong].next=head[u];
head[u]=yong++;
}
void Dcreat(int u,int v,int w) {
creat(u,v,w);
creat(v,u,w);
}
struct nodee {
int len,v;
friend bool operator<(nodee a,nodee b) {
if(a.len!=b.len)
return a.len>b.len;
return a.v>b.v;
}
};
int dijkstra(int u,int end) {
int dis[N],i,j,visit[N];
memset(visit,0,sizeof(visit));
for(i=0;i<n;i++)
dis[i]=inf;
dis[u]=0;
//typedef pair<int ,int >p;
//priority_queue<p,vector<p>,greater<p> >q;
// q.push(make_pair(dis[u],u));
priority_queue<nodee>q;
nodee cur,now;
cur.len=0;
cur.v=u;
q.push(cur);
while(!q.empty()) {
nodee cur=q.top();
// j=cur.second;
q.pop();
if(visit[cur.v])continue;
visit[cur.v]=1;
for(i=head[cur.v];i!=-1;i=bian[i].next)
if(dis[bian[i].v]>dis[cur.v]+bian[i].w) {
dis[bian[i].v]=dis[cur.v]+bian[i].w;
now.len=dis[bian[i].v];
now.v=bian[i].v;
q.push(now);
}
}
if(dis[end]<inf)
return dis[end];
return -1;
}
int main() {
int i,j,a,b;
while(scanf("%d%d",&n,&m)!=EOF) {
yong=0;
memset(head,-1,sizeof(head));
while(m--) {
scanf("%d%d%d",&a,&b,&j);
Dcreat(a,b,j);
}
scanf("%d%d",&a,&b);
printf("%d\n",dijkstra(a,b));
}
return 0;
}
hdu 1874 dijkstra 队列实现 比数组高效特别在稀疏图的更多相关文章
- hdu 1874 Dijkstra算法
先贴个网上找的比较通俗易懂的教程: 2.1Dijkstra算法(非负权,使用于有向图和无向图) Dijkstra算法是典型最短路算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心 ...
- ACM: HDU 1874 畅通工程续-Dijkstra算法
HDU 1874 畅通工程续 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Desc ...
- HDU 1874 畅通工程续-- Dijkstra算法详解 单源点最短路问题
参考 此题Dijkstra算法,一次AC.这个算法时间复杂度O(n2)附上该算法的演示图(来自维基百科): 附上: 迪科斯彻算法分解(优酷) problem link -> HDU 1874 ...
- (重刷)HDU 1874 畅通工程续 + HDU 2544 最短路 最短路水题,dijkstra解法。
floyd解法 今天初看dijkstra,先拿这两题练手,其他变形题还是不是很懂. 模版题,纯练打字... HDU 1874: #include <cstdio> #define MAXN ...
- HDU 1874 畅通工程续(初涉dijkstra算法实现)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 dijkstra算法实现可参照此博客学习:http://www.cnblogs.com/biye ...
- hdu 2544 hdu 1874 poj 2387 Dijkstra 模板题
hdu 2544 求点1到点n的最短路 无向图 Sample Input2 1 //结点数 边数1 2 3 //u v w3 31 2 52 3 53 1 20 0 Sample Output32 ...
- HDU 2544 最短路(floyd+bellman-ford+spfa+dijkstra队列优化)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目大意:找点1到点n的最短路(无向图) 练一下最短路... dijkstra+队列优化: #i ...
- hdu 1874 畅通工程续(迪杰斯特拉优先队列,floyd,spfa)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- hdoj 1874 dijkstra
在做PAT的甲1003,思考DFS和图什么的,时间紧张直接去看柳神(日后上传柳神的C++版本)的订阅,得知是dijkstra,转去用hdoj 1874练手,写了两天,终于调出来了 题目链接:http: ...
随机推荐
- bzoj 1615: [Usaco2008 Mar]The Loathesome Hay Baler麻烦的干草打包机【bfs】
直接bfs即可,注意开double,还有驱动和终点的齿轮都在序列里,要把它们找出来= = #include<iostream> #include<cstdio> #includ ...
- vue.js学习文档
1.实例化vue对象 new Vue(){ } 2.对象属性 el: 控制的属性 data: 数据存储位置 methods: 方法存储位置 template: 模板样式 computed: 计算属性 ...
- JDK API文档下载
java SE 8 API文档:http://www.oracle.com/technetwork/java/javase/documentation/jdk8-doc-downloads-21331 ...
- Visual Studio Code -VS Code
VS Code 免费开源的编辑器,支持 windows. mac. Linux. 微软出品 官网:https://code.visualstudio.com/ 下载地址:https://code.vi ...
- Ngnix SSL配置(HTTP、HTTPS兼容)
一.使用阿里云提供证书 下载aliyun证书for Nginx,解压出两个文件,.pem和.key文件 在nginx安装目录Conf文件夹下新建cert文件夹,拷贝两个密钥文件 二.配置nginx 打 ...
- ubuntu系统nginx+Redis+PHP
一.安装ngnix apt-get update sudo apt-get install nginx /etc/init.d/nginx start 二.安装php sudo apt-get ins ...
- document.mozFullScreen
非标准该特性是非标准的,请尽量不要在生产环境中使用它! 概述 返回一个布尔值,表明当前文档是否处于全屏模式. 语法 var isFullScreen = document.mozFullScreen ...
- tee命令用法
用途说明 在执行Linux命令时,我们可以把输出重定向到文件中,比如 ls >a.txt,这时我们就不能看到输出了,如果我们既想把输出保存到文件中,又想在屏幕上看到输出内容,就可以使用tee命令 ...
- CAD绘制一个单行文字(com接口VB语言)
主要用到函数说明: _DMxDrawX::DrawText 绘制一个单行文字.详细说明如下: 参数 说明 DOUBLE dPosX >文字的位置的X坐标 DOUBLE dPosY 文字的位置的Y ...
- JavaScript 实现页面中录音功能
页面中实现录音需要使用浏览器提供的 MediaRecorder API,所以前提是需要浏览器支持 MediaStream Recording 相关的功能. 以下代码默认工作在 Chrome 环境中. ...