参考  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 队列实现 比数组高效特别在稀疏图的更多相关文章

  1. hdu 1874 Dijkstra算法

    先贴个网上找的比较通俗易懂的教程: 2.1Dijkstra算法(非负权,使用于有向图和无向图) Dijkstra算法是典型最短路算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心 ...

  2. ACM: HDU 1874 畅通工程续-Dijkstra算法

    HDU 1874 畅通工程续 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Desc ...

  3. HDU 1874 畅通工程续-- Dijkstra算法详解 单源点最短路问题

    参考 此题Dijkstra算法,一次AC.这个算法时间复杂度O(n2)附上该算法的演示图(来自维基百科): 附上:  迪科斯彻算法分解(优酷) problem link -> HDU 1874 ...

  4. (重刷)HDU 1874 畅通工程续 + HDU 2544 最短路 最短路水题,dijkstra解法。

    floyd解法 今天初看dijkstra,先拿这两题练手,其他变形题还是不是很懂. 模版题,纯练打字... HDU 1874: #include <cstdio> #define MAXN ...

  5. HDU 1874 畅通工程续(初涉dijkstra算法实现)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874 dijkstra算法实现可参照此博客学习:http://www.cnblogs.com/biye ...

  6. 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 ...

  7. HDU 2544 最短路(floyd+bellman-ford+spfa+dijkstra队列优化)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目大意:找点1到点n的最短路(无向图) 练一下最短路... dijkstra+队列优化: #i ...

  8. hdu 1874 畅通工程续(迪杰斯特拉优先队列,floyd,spfa)

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  9. hdoj 1874 dijkstra

    在做PAT的甲1003,思考DFS和图什么的,时间紧张直接去看柳神(日后上传柳神的C++版本)的订阅,得知是dijkstra,转去用hdoj 1874练手,写了两天,终于调出来了 题目链接:http: ...

随机推荐

  1. Springboot拦截器线上代码失效

    今天想测试下线上代码,能否正常的执行未登录的拦截.所以把拦截器的代码给开放出来,但是没想到线上代码addInerceptors(InterceptorRegistry registry) 这个方法一直 ...

  2. 洛谷2019 3月月赛 T1

    题干 2019第一次月赛 我只有255pts T1还是比较水的... 海星 T1一道简单的模拟(就是有坑..导致很多人不能一次性AC 比如说我) _3个坑点 1.位数问题 2.-0 3.0... #i ...

  3. 最大流增广路(KM算法) HDOJ 1853 Cyclic Tour

    题目传送门 /* KM: 相比HDOJ_1533,多了重边的处理,还有完美匹配的判定方法 */ #include <cstdio> #include <cmath> #incl ...

  4. Python学习日记之忽略删除字符串空白

    使用Python自带的函数strip可以剔除字符串开头.结尾.两端的空白 使用场景:用户输入验证 strip : 去除字符串两端的空白 rstrip : 去除字符串末尾(右端)的空白 lstrip : ...

  5. JProfiler 9.1.1部署及使用

    软件准备: 官网下载地址:http://www.ej-technologies.com/download/jprofiler/files 软件部署: windows安装双击即可. 注册号: L-Lar ...

  6. 安装FCIS问题汇总

    安装官网安装步骤时可能出现的问题: "/usr/bin/ld: cannot find -lopenblas" error 解决方案: apt install liblapack- ...

  7. Markdown(github)语法

    << 访问 Wow!Ubuntu NOTE: This is Simplelified Chinese Edition Document of Markdown Syntax. If yo ...

  8. OpenTSDB监控

    OpenTSDB监控

  9. 梦想iOS版CAD控件2018.11.07更新

    下载地址: http://www.mxdraw.com/ndetail_10110.html 1.  增加iOS上的CAD绘图接口和使用例子 2.  增加动态交互使用例子 3.  把Android上改 ...

  10. 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList

    package algorithms; import java.util.ArrayList; import java.util.Stack; /** * public class ListNode ...