一般的dijkstra算法利用贪心的思想,每次找出最短边,然后优化到其他点的的距离,我们还采用贪心思路,但在寻找最短边进行优化,之前是双重for循环,现在我们用优先队列来实现。

代码解释:

//样例程序采用边表储存。

#include<cstdio>
#include<queue>
#include<cstring>
#include<cmath>
#include<iostream>

using namespace std;

int head[100000]={0},next[200000]={0},aa[200000]={0},size,s,tt,m,n;

struct bb
{
int x,y;
}a[100000];//记录点的横纵坐标。
double val[100000],dis[100000]={0};

void add(int h,int t,double c)//建立边表。
{
size++;//对边进行重编号。
next[size]=head[h];
head[h]=size;
aa[size]=t;
val[size]=c;
}

void init()
{
scanf("%d",&n);
for (int i=0;i<n;i++)
{
int u,v;
double c;
scanf("%d%d",&u,&v); //读入有边的两点。
c=sqrt((a[u-1].x-a[v-1].x)*(a[u-1].x-a[v-1].x)+(a[u-1].y-a[v-1].y)*(a[u-1].y-a[v-1].y));//用数学公式求出两点间距离。
add(u,v,c);//建立由u到v的边,权值为c;
add(v,u,c);//若图为有向图,则省略该语句。
}
scanf("%d%d",&s,&tt); //读入所求的由s到tt的距离。目标。
}

void initint()//存下点的坐标。
{
scanf("%d",&m);
for (int i=0;i<m;i++)
scanf("%d%d",&a[i].x,&a[i].y);
}

struct ss//定义优先队列的自定义结构体。
{
int x;
double y;
ss(){}//定义构造函数。
ss(int xx,double yy)//重载该函数。
{
x=xx;
y=yy;
}

bool operator<(const ss& b)const//重载<运算符(因为我们要找最小值,而优先队列默认为大根堆)。
{
return y>b.y;
}
};

void dij()//dijkstra算法
{
priority_queue<ss>que;//定义优先队列,不懂看“C++之路启航——标准模板库(queue)”
que.push(ss(s,0));//把起点压入队列中。
for (int i=0;i<=m;i++)//
dis[i]=100000000;
dis[s]=0;// 初始操作。
while (!que.empty())
{
ss op=que.top();//取出最小值。op.x为点的编号,op.y为从起点到该点的距离。
que.pop();
if (op.y>dis[op.x]) continue;//一步优化。
for (int i=head[op.x];i!=0;i=next[i]) //遍历与该点相连的边。
{
int j=aa[i];
if (dis[j]>dis[op.x]+val[i])//找到能够更新的,并且压入队列中。
{
dis[j]=dis[op.x]+val[i];
que.push(ss(j,dis[j]));
}
}
}
printf("%.2f",dis[tt]);//输出;
return;
}

int main()
{
initint();
init();
dij();
return 0;
}

C++之路进阶——优先队列优化最短路径算法(dijkstra)的更多相关文章

  1. 最短路径算法Dijkstra和A*

    在设计基于地图的游戏,特别是isometric斜45度视角游戏时,几乎必须要用到最短路径算法.Dijkstra算法是寻找当前最优路径(距离原点最近),如果遇到更短的路径,则修改路径(边松弛). Ast ...

  2. 最短路径算法-Dijkstra算法的应用之单词转换(词梯问题)(转)

    一,问题描述 在英文单词表中,有一些单词非常相似,它们可以通过只变换一个字符而得到另一个单词.比如:hive-->five:wine-->line:line-->nine:nine- ...

  3. 有向有权图的最短路径算法--Dijkstra算法

    Dijkstra算法 1.定义概览 Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.Di ...

  4. 最短路径算法——Dijkstra,Bellman-Ford,Floyd-Warshall,Johnson

    根据DSqiu的blog整理出来 :http://dsqiu.iteye.com/blog/1689163 PS:模板是自己写的,如有错误欢迎指出~ 本文内容框架: §1 Dijkstra算法 §2 ...

  5. 图论最短路径算法——Dijkstra

    说实在的,这算法很简单,很简单,很简单--因为它是贪心的,而且码量也小,常数比起SPFA也小. 主要思想 先初始化,dis[起点]=0,其它皆为无限大. 还要有一个bz数组,bz[i]表示i是否确定为 ...

  6. 带权图的最短路径算法(Dijkstra)实现

    一,介绍 本文实现带权图的最短路径算法.给定图中一个顶点,求解该顶点到图中所有其他顶点的最短路径 以及 最短路径的长度.在决定写这篇文章之前,在网上找了很多关于Dijkstra算法实现,但大部分是不带 ...

  7. 最短路径算法——Dijkstra算法

    在路由选择算法中都要用到求最短路径算法.最出名的求最短路径算法有两个,即Bellman-Ford算法和Dijkstra算法.这两种算法的思路不同,但得出的结果是相同的. 下面只介绍Dijkstra算法 ...

  8. 最短路径算法——Dijkstra算法与Floyd算法

    转自:https://www.cnblogs.com/smile233/p/8303673.html 最短路径 ①在非网图中,最短路径是指两顶点之间经历的边数最少的路径. AE:1    ADE:2  ...

  9. 优先队列优化dij算法

    之前已经弄过模板了,但那个复杂一点,这个就是裸的dij,用起来更方便 输入格式:n,m,s,d分别是点数,边数,起点,终点 之后m行,输入x,y,z分别是两点即权值 题目链接:https://www. ...

随机推荐

  1. 数据库主键跟外键+修改mysql的密码

    update myspl.user set password=PASSWORD(设置的密码)  where user='root'; 如果修改错误:先执行use mysple;再重复上面的代码. 一. ...

  2. 【C51】单片机中断

    引言 其实人的一生和单片机的运行很类似.就拿人的一生来说:有些事只需要做一次,比如得了水痘以后,体内产生免疫,以后就不会再生这个病了.有些事需要反复做,比如反复读书,反复工作,反复与困苦打交道,反复地 ...

  3. win7下vs2010编译生成sqlite3.dll库

    http://blog.csdn.net/qing666888/article/details/53582262 http://download.csdn.net/detail/qing666888/ ...

  4. 动态页面的登陆——装饰器应用<代码>

    log_status = False f = open("info", "r", encoding="utf8") source = f.r ...

  5. JS实现一个简单的计算器

    使用JS完成一个简单的计算器功能.实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除.效果如上: 第一步: 创建构建运算函数count(). 第二步: 获取两个输入框中的值和获取选择 ...

  6. 转:[ASP.NET]重構之路系列v4 – 簡單使用interface之『你也會IoC』

    前言 上次v3版本,我們將Entity, Service, Dao, Utility都放到了類別庫裡面,讓我們可以輕鬆的在不同專案中用同一份組件.雖然文章沒有獲得太多的讚賞,不過相信那一定是太多人會這 ...

  7. 使用git Rebase让历史变得清晰

    当多人协作开发一个分支时,历史记录通常如下方左图所示,比较凌乱.如果希望能像右图那样呈线性提交,就需要学习git rebase的用法. “Merge branch”提交的产生 我们的工作流程是:修改代 ...

  8. css中的zoom的使用

    css中的zoom的使用  zoom : normal | number  normal : 默认值.使用对象的实际尺寸  number : 百分数 | 无符号浮点实数.浮点实数值为1.0或百分数为1 ...

  9. css3画图之大白(●—●)

    把大白送给你~ <!DOCTYPE html> <html> <head> <title>大白</title> <meta http- ...

  10. python笔记 - day3

    python笔记 - day3 参考:http://www.cnblogs.com/wupeiqi/articles/5453708.html set特性: 1.无序 2.不重复 3.可嵌套 函数: ...