Dij:贪心思想的单源最短路,时间复杂度O(n^2)。

Dij算法流程:

  1. d数组记录源点s到每个点的距离,若无边则设为inf,标记源点;
  2. 选出d数组中未标记的最小值,该节点记为k,并标记k为已求出最短路;
  3. 枚举每个节点(记为j),若经过k到达j的路径<d[j]且未标记,则更新d[j];
  4. 重复2、3步n次;
  5. d[v]为s-v的最短路;

堆优Dij:即用堆优化的dij算法,时间复杂度O(nlogn);(但是据说跑起来比spfa快?求神犇解释)

堆优Dij算法流程:

  1. q为priority_queue,优先队列记录一个二元组,分别为索引位置和数值;

    d数组记录源点s到每个点的距离,若无边则设为inf;

  2. 源点入队;
  3. 队首出队并标记队首;
  4. 遍历队首的邻接点,若可松弛,则更新该邻接点的最短路并将该节点压入优先队列;

不知道为什么,写出来的spfa和堆优dij的唯一区别就是spfa的队列变成了dij的优先队列,也不知道这样对不对,若有错误希望大家指出。

经测试,其实无需标记,堆优dij是照着dij模板改的,求解释。。。

例题:Codevs2038香甜的黄油

 #include<cstdio>
#include<cmath>
#include<queue>
#include<vector>
#include<cstring>
using namespace std; struct edge{
int to;
int w;
int next;
}; struct node{
int index,value;
node(){};
node(int x,int y){index=x;value=y;}//构造函数
friend bool operator < (node a,node b){
return a.value>b.value;
}//重载小于号
}; priority_queue<node> q;
edge e[];
int ne=,head[],d[],a[],answer[]={};
bool b[]; void add(int a,int b,int c){
e[++ne].to=b;e[ne].w=c;e[ne].next=head[a];head[a]=ne;
} void dij(int k){//k为源点编号
int i,v;
node u;
memset(d,,sizeof(d));
memset(b,,sizeof(b));//初始化
d[k]=;
//b[k]=true;
q.push(node(k,));//构造并压入源点
while(!q.empty()){
u=q.top();q.pop();//弹出队首
//if(b[u.index])continue;
//b[u.index]=true;//标记
for(i=head[u.index];i!=-;i=e[i].next){//遍历邻接点
v=e[i].to;
if(u.value+e[i].w<d[v]/*&&b[v]==false*/){
d[v]=u.value+e[i].w;//松弛操作
q.push(node(v,d[v]));//压入新节点
}
}
}
} int main(){
int n,p,c,ans=,i,j,u,v,w;
memset(head,-,sizeof(head));
memset(e,,sizeof(e));
scanf("%d%d%d",&n,&p,&c);
for(i=;i<=n;i++)scanf("%d",&a[i]);
for(i=;i<=c;i++){
scanf("%d%d%d",&u,&v,&w);
add(u,v,w);
add(v,u,w);//连边
}
for(i=;i<=p;i++){
dij(i);
int sum=;
for(j=;j<=n;j++)sum+=d[a[j]];
ans=min(ans,sum);
}
printf("%d\n",ans);
}

堆优DIJ模板的更多相关文章

  1. B20J_2007_[Noi2010]海拔_平面图最小割转对偶图+堆优化Dij

    B20J_2007_[Noi2010]海拔_平面图最小割转对偶图+堆优化Dij 题意:城市被东西向和南北向的主干道划分为n×n个区域.城市中包括(n+1)×(n+1)个交叉路口和2n×(n+1)条双向 ...

  2. [CF1209F]Koala and Notebook_堆优化dij

    Koala and Notebook 题目链接:https://codeforces.com/contest/1209/problem/F 数据范围:略. 题解: 开始的时候看错题了....莫名其妙多 ...

  3. [CF1146D]Frog Jumping_exgcd_堆优化dij

    Frog Jumping 题目链接:http://codeforces.com/contest/1146/problem/D 数据范围:略. 题解: 首先发现,如果$x\ge a +b$,那么所有的$ ...

  4. 【模板】堆优化 + dij +pair 存储

    就是短 感谢Cptraserdalao的博客 #include<bits/stdc++.h> using namespace std; struct node { int val,num; ...

  5. 链式前向星实现的堆优化dij求最短路模板

    #include<cstdio> #include<string> #include<cstdlib> #include<cmath> #include ...

  6. 【洛谷P1462】【二分+堆优化dij】

    题目描述 在艾泽拉斯,有n个城市.编号为1,2,3,...,n. 城市之间有m条双向的公路,连接着两个城市,从某个城市到另一个城市,会遭到联盟的攻击,进而损失一定的血量. 每次经过一个城市,都会被收取 ...

  7. 堆优化dij

    #include<iostream> #include<cstdio> #include<queue> using namespace std; ],head[], ...

  8. 2017多校第9场 HDU 6166 Senior Pan 堆优化Dij

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6166 题意:给你一个有向图,然后给你k个点,求其中一个点到另一个点的距离的最小值. 解法:枚举二进制位 ...

  9. 【luogu P3377 左偏树(可并堆)】 模板

    题目连接:https://www.luogu.org/problemnew/show/P3377 #include <cstdio> #include <cstring> #i ...

随机推荐

  1. one_day_one_linuxCmd---光标快捷操作

    <坚持每天学习一个 linux 命令,今天我们来学习 切换光标的常用命令> 摘要:最近经常使用 xshell 软件来远程连接各种机器,在 bin/bash 下输入各种命令,因为都是一些非常 ...

  2. pandas中DataFrame重置设置索引

    在pandas中,经常对数据进行处理 而导致数据索引顺序混乱,从而影响数据读取.插入等. 小笔总结了以下几种重置索引的方法: import pandas as pd import numpy as n ...

  3. 当初对"软件工程"这个专业的期待和想象是什么?

    很多期待,很多幻想 印象很深刻的初中语文老师让我们背诵的一首诗<错误>: <错误> 作 者:郑愁予 我打江南走过 那等在季节里的容颜如莲花的开落 东风不来,三月的柳絮不飞 你底 ...

  4. Java Properties基础知识总结

    在Java语言中,使用一种以.properties为扩展名的文本文件作为资源文件,该类型的文件的内容格式为类似: some_key=some_value #注释描述 还有一种是使用xml文件保存项目的 ...

  5. MySQL的InnoDB的幻读问题

    MySQL InnoDB事务的隔离级别有四级,默认是“可重复读”(REPEATABLE READ). 未提交读(READ UNCOMMITTED).另一个事务修改了数据,但尚未提交,而本事务中的SEL ...

  6. 《Docekr入门学习篇》——Docker仓库harbor

    Harbor Harbor仓库介绍 我们在日常Docker容器使用和管理过程中,渐渐发现部署企业私有仓库往往是很有必要的, 它可以帮助你管理企业的一些敏感镜像, 同时由于Docker Hub的下载速度 ...

  7. 201509-1 数列分段 Java

    思路: 后一个和前一个不相等就算一段 import java.util.Scanner; public class Main { public static void main(String[] ar ...

  8. 【转载】解决Cannot download "https://github.com/sass/node-sass/releases/download...问题

    因很早做了一个小demo,并且在其他成熟的电脑上(node配置好的)下载依赖包没什么问题,最近就在新的电脑上配置好所有东西后,去下载这个demo的依赖包,就出现了node-sass无法正常解析的问题, ...

  9. Vue插件配置和 后台交互

    Vue插件配置和 后台交互 一.全局配置静态文件(csss, js..) 1.1 全局配置css文件 创建css文件 在main.js配置css文件 // 配置全局css样式 // 方式一 impor ...

  10. Python笔记_第一篇_面向过程_第一部分_8.画图工具(小海龟turtle)

    turtle 是一个简单的绘图工具. 提供一个小海龟,可以把它理解为一个机器人,只能听懂有限的命令,且绘图窗口的原点(0,0)在中间,默认海龟的方向是右侧海龟的命令包括三类:运动命令.笔画控制命令.其 ...