写一下SPFA和迪杰斯特拉的模版。。。第一次写博客,有错请提出哦!
SPFA的模版
#include<bits/stdc++.h>
using namespace std;
queue <int> q;
typedef pair <int , int> PII;
vector <PII> s[];
int m,n,x,y,val,dian[],zou[],rankk,zhong;
main(){
scanf("%d%d",&n,&m);//n个点,m条边;
for(int i=;i<=m;i++)//存边,是无向图;
{
scanf("%d%d%d",&x,&y,&val);
s[x].push_back(PII(y,val));
s[y].push_back(PII(x,val));
}
memset(dian,,sizeof(dian));
dian[]=;
q.push();
zou[]=;
while(!q.empty())
{
rankk=q.front();
q.pop();
zou[rankk]=;
for(int i=;i<s[rankk].size();i++)//枚举每一条边,判断是否可以更新;
{
zhong=s[rankk][i].first;
val=s[rankk][i].second;
if(dian[zhong]>dian[rankk]+val)
{
dian[zhong]=dian[rankk]+val;
if(zou[zhong]==)
continue;
q.push(zhong);
zou[zhong]=;
}
}
}
//这样,从1到X的最短距离就存在dian[x]里面的;
}
//迪杰斯特拉的模版
#include<bits/stdc++.h>
using namespace std;
struct edge{ //只是一个结构体而已 ;
int rank,val;
};
priority_queue <edge> q; //优先队列,存着结构体;
bool operator <(edge a,edge b) //为优先队列排序
{
return a.val > b.val ;
}
typedef pair <int , int> PII; //第一个INT存着指向的编号,第二个INT存着距离;
vector <PII> s[];
int n,m,x,y,val,zhong,rankk,dian[],zou[];//zou代表有没有走过,点代表从1到x点的距离dian[x];
main(){
scanf("%d%d",&n,&m);//n个点,m条边;
for(int i=;i<=m;i++)//存边,是无向图;
{
scanf("%d%d%d",&x,&y,&val);
s[x].push_back(PII(y,val));
s[y].push_back(PII(x,val));
}
memset(dian,,sizeof(dian));//初始化点为无限大,最好不要用127,小心加起来时爆掉;
edge E;
E.rank = ;
q.push(E); //存入开始点的信息;
zou[] = ;
dian[] = ;
while(!q.empty())
{
rankk=q.top().rank;//队首的点的编号;
q.pop();
if(zou[rankk]==)//判断是否走过 ;
continue;
zou[rankk] = ;
for(int i=;i<s[rankk].size();i++)//枚举每一条边,判断是否可以更新;
{
zhong=s[rankk][i].first;
val=s[rankk][i].second;
if(dian[zhong]>dian[rankk]+val)
{
dian[zhong]=dian[rankk]+val;
edge E;
E.rank = zhong;
E.val = dian[zhong];
q.push(E);//可以更新就重新存入队列;
}
}
}
//这样,从1到X的最短距离就存在dian[x]里面的;
}
写一下SPFA和迪杰斯特拉的模版。。。第一次写博客,有错请提出哦!的更多相关文章
- 算法与数据结构(六) 迪杰斯特拉算法的最短路径(Swift版)
上篇博客我们详细的介绍了两种经典的最小生成树的算法,本篇博客我们就来详细的讲一下最短路径的经典算法----迪杰斯特拉算法.首先我们先聊一下什么是最短路径,这个还是比较好理解的.比如我要从北京到济南,而 ...
- 迪杰斯特拉算法——PAT 1003
本文主要是将我对于我对于迪杰斯特拉算法的理解写出来,同时通过例题来希望能够加深对于算法的理解,其中有错误的地方希望大家指正. 迪杰斯特拉算法 我将这个算法理解成一个局部到整体的算法,这个方法确实越研究 ...
- hdu 1874 畅通工程续(迪杰斯特拉优先队列,floyd,spfa)
畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- 迪杰斯特拉和spfa
迪杰斯特拉 Dijkstra算法是典型的算法.Dijkstra算法是很有代表性的算法.Dijkstra一般的表述通常有两种方式,一种用永久和临时标号方式,一种是用OPEN, CLOSE表的方式,这里均 ...
- C#迪杰斯特拉算法
C#迪杰斯特拉算法 网上有许多版本的,自己还是写一个理解点 Dijkstra.cs public class Dijkstra { private List<Node> _nodes; p ...
- 最短路径之迪杰斯特拉(Dijkstra)算法
迪杰斯特拉(Dijkstra)算法主要是针对没有负值的有向图,求解其中的单一起点到其他顶点的最短路径算法.本文主要总结迪杰斯特拉(Dijkstra)算法的原理和算法流程,最后通过程序实现在一个带权值的 ...
- Dijkstra(迪杰斯特拉)源最短路径 小白说明
源最短路径 小白说明 Dijkstra算法,书上其实说的很简洁,仔细看,仔细思考是会理解的.但要先理解几条引论和推理. 而自己思考的思路在不需要任何推理只从贪心思路出发,和Dijkstra有所不同,但 ...
- dijkstra算法(迪杰斯特拉算法)
dijkstra算法(迪杰斯特拉算法) 用途:有向图最短路径问题 定义:迪杰斯特拉算法是典型的算法,一般的表述通常有两种方式,这里均采用永久和临时标号的方式,该算法要求图中不存在负权边 用永久和临时标 ...
- HDU6166-Senior Pan-Dijkstra迪杰斯特拉算法(添加超源点,超汇点)+二进制划分集合-2017多校Team09
学长好久之前讲的,本来好久好久之前就要写题解的,一直都没写,懒死_(:з」∠)_ Senior Pan Time Limit: 12000/6000 MS (Java/Others) Memor ...
随机推荐
- 使用spring提供的@Scheduled注解创建定时任务
使用方法 操作非常简单,只要按如下几个步骤配置即可 1. 导入jar包或添加依赖,其实定时任务只需要spring-context即可,当然起服务还需要spring-web: 2. 编写定时任务类和方法 ...
- 《计算机程式设计》Week4 课堂笔记
本笔记记录自 Coursera课程 <计算机程式设计> 台湾大学 刘邦锋老师 Week4 Functions 4-1 System Function 函数主要分为两大类系统定义函数与使用者 ...
- 类HashSet
/* * Collection * * List * 有序(存储顺序和取出顺序一致),可以重复 * * Set * 无序(存储顺序和取出顺序不一致),唯一 * * */ import java.uti ...
- 孩子王app自动签到送现金券
今天在某商场的孩子王店给小孩买东西时发现,app连续签到3天即可获得一张5元现金券. 回到家中,花几分钟Fiddler抓包分析写了个自动签到的代码. var cookies = new string[ ...
- 【ABAP系列】SAP 关于出口(user-exit)MV50AFZ1的一些问题
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP 关于出口(user-ex ...
- 关于this在不同使用情况表示的含义
1. addEventListener 函数中的this 指向的是出发事件的事件源 obj.addEventListener('click',function(){ console.log(thi ...
- 前端 CSS层叠性 CSS选择器优先级
层叠性 层叠性:权重的标签覆盖掉了权重小的标签,说白了 ,就是被干掉了 权重:谁的权重大,浏览器就会显示谁的属性 我们现在已经学过了很多的选择器,也就是说在一个HTML页面中有很多种方式找到一个元素并 ...
- python基础-8迭代器(iter)和生成器(yield)
一 生成器 从Python2.2起,生成器提供了一种简洁的方式帮助返回列表元素的函数来完成简单和有效的代码. 它基于yield指令,允许停止函数并立即返回结果.此函数保存其执行上下文,如果需要,可立即 ...
- 【洛谷p1970】花匠
莫得致敬lz谢谢.lz的题解是优秀的题解谢谢! 看算法标签 但是我并不会DP的思路,用一个很神奇的码量超级少的代码(虽然我码了超多),然后其实这个数据可以看做是一个函数嘛对吧:(比如说样例) 那么要注 ...
- CVE-2016-2502-drivers/usb/gadget/f_serial.c in the Qualcomm USB driver in Android. Buffer Overflow Vulnerability reported by #plzdonthackme, Soctt.
CVE-2016-2502-drivers/usb/gadget/f_serial.c in the Qualcomm USB driver in Android.Buffer Overflow Vu ...