Dijkstra算法(c++版)

最短路径(DP的应用)
单源最短路径,不允许出现负环
核心思想:更新估算距离,松弛
δ(u,v)≤δ(u,x)+δ(x,v)\delta(u, v) \leq \delta(u, x) + \delta(x, v) δ(u,v)δ(u,x)+δ(x,v)

时间复杂度与采用的数据结构有关,标准的dijkstra应该是用堆实现的。
Array O(v2v^2v2)
Binary heap O((V+E)lgV(V+E)lgV(V+E)lgV)
Fibonacci heap O(E+VlgVE+VlgVE+VlgV)

如果对于所有的边权值均为1,那么Dijkstra算法可以用BFS实现
使用FIFO队列代替Priority队列,其时间复杂度为O(V+EV+EV+E)

数组实现:

#include <iostream>
using namespace std;
void dijkstra();
int e[10][10];
int vis[10];
int dis[10];
int n, m;
int min1 = 99999999;
int u = 0;
int main()
{cin >> n >> m;// 初始化邻接表for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){if (i == j){e[i][j] = 0;}else{e[i][j] = 99999999;}}}// 填充数据for (int i = 1; i <= m; i++){int a, b, c;cin >> a >> b >> c;e[a][b] = c;}for (int i = 1; i <= n; i++){dis[i] = e[1][i];}vis[1] = 1;dijkstra();for (int i = 1; i <= n; i++){cout << dis[i];}system("pause");return 0;
}
void dijkstra()
{for (int i = 1; i <= n - 1; i++){min1 = 99999999;// 寻找权值最小的点ufor (int j = 1; j <= n; j++){if (vis[j] == 0 && dis[j] < min1){min1 = dis[j];u = j;}}vis[u] = 1;for (int v = 1; v <= n; v++){// 对于每个u可达的v来说if (e[u][v] < 99999999){// 如果当前的dis[v]不满足三角形不等式,那么进行松弛操作if (dis[v] > dis[u] + e[u][v]){dis[v] = dis[u] + e[u][v];}}}}
}

堆实现

#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <vector>
using namespace std;
const int Ni = 10000;
const int INF = 1 << 27;
struct node
{int point, value;// 构造node(int a, int b){point = a;value = b;}// 重载<操作符bool operator<(const node &a) const{// 对小于运算符进行重载,如果两个值相等,那么继续判断point,如果不等,则返回falseif (value == a.value){return point < a.point;}else{return value > a.value;}}
};
vector<node> e[Ni];
int dis[Ni], n;
priority_queue<node> q;
void dijkstra();
int main()
{int a, b, c, m;scanf("%d%d", &n, &m);while (m--){scanf("%d%d%d", &a, &b, &c);e[a].push_back(node(b, c));e[b].push_back(node(a, c));}// for (int i = 0; i <= n; i++)// {//     dis[i] = INF;// }memset(dis, 0x3f, sizeof(dis));dis[1] = 0;// 优先队列,队头元素最大,但是如果类型为struct需要重载<运算符q.push(node(1, dis[1]));dijkstra();for (int i = 1; i <= n; i++){printf("%d ", dis[i]);}system("pause");return 0;
}
void dijkstra()
{while (!q.empty()){node x = q.top();q.pop();for (int i = 0; i < e[x.point].size(); i++){node y = e[x.point][i];if (dis[y.point] > dis[x.point] + y.value){dis[y.point] = dis[x.point] + y.value;q.push(node(y.point, dis[y.point]));}}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/569613.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

day1-参数化关联函数响应断言

1、参数化 1&#xff09;、准备参数化文件 2&#xff09;&#xff0c;添加CSV数据文件设置 3&#xff09;、在请求里 引用参数 2、关联函数 1&#xff09;、给学生充值金币需要从登录返回获取登录cookie 在登录接口添加后置处理器JSON Extractor 用户登录返回结果为&#xff1…

MySQL 8.0 error 2059: Authentication plugin 'caching_sha2_password' cannot be loaded

安装MYSQL8.0版本之后&#xff0c;使用可视化管理工具Workbench或者Navicat都会产生一个类似的报错。 原因&#xff1a;MYSQL8.0之前的版本中加密规则为mysql_native_password. 而mysql8之后的加密规则为caching_sha2_password. 解决办法&#xff1a; 打开CMD进入MYSQL&#…

语句覆盖,判定覆盖,条件覆盖,条件/判定覆盖,条件组合覆盖,路径覆盖

最近在复习软件测试的考试&#xff0c;每次到白盒测试这里都要为这几种逻辑覆盖方法感到头疼&#xff0c;这次终于决定好好整理出来。 逻辑覆盖是通过对程序逻辑结构的遍历实现程序的覆盖。它是一系列测试过程的总称&#xff0c;这组测试过程逐渐进行越来越完整的通路测试。 根…

PHP实现简单文件上传系统

目录结构如下&#xff0c;其中包含两个代码文件和一个uploads文件夹&#xff08;用于存放上传的文件&#xff09; index.php 该代码实现html页面&#xff0c;包括需要填写学号和姓名&#xff0c;上传文件大小不得超过20M <form action"fileSystem.php" method&…

Android中LayoutInflater()方法

在实际开发中LayoutInflater这个类还是非常有用的&#xff0c;它的作用类似于findViewById()。不同点是LayoutInflater是用来找res/layout/下的xml布局文件&#xff0c;并且实例化&#xff1b;而findViewById()是找xml布局文件下的具体widget控件(如Button、TextView等)。 1、对…

Vue入门 ---- 仿百度搜索

简述 学习vue的第二节&#xff0c;由于2.0版本并不向下兼容&#xff0c;视频中的不少内不能实现。下面列出一些主要知识点 // v-on 可简写为 // 事件冒泡是指当点击div内部的button触发show1()时&#xff0c;必然会冒泡到div上执行show2()&#xff0c;这才层级div中很常见 // …

洛谷 P3367 ---- 【模板】并查集

题目描述 给出一个并查集&#xff0c;请完成合并和查询操作。 输入格式: 第一行包含两个整数N、M&#xff0c;表示共有N个元素和M个操作。 接下来M行&#xff0c;每行包含三个整数Zi、Xi、Yi 当Zi1时&#xff0c;将Xi与Yi所在的集合合并 当Zi2时&#xff0c;输出Xi与Yi是否在…

win10家庭版删除文件提示没有权限最简单的方式

1、cmd 2、右键-以管理员身份运行&#xff08;重要&#xff09; 3、输入&#xff1a;net user administrator /active:yes&#xff0c;开启超级管理员账号 4、winr键打开运行对话框&#xff0c;输入 netplwiz &#xff0c;重设administrator密码 5、重启-开始→切换账户→Admi…

Visual Studio引入外部库 ---- 弄懂静态库lib和动态库dll

这两天由于想要研究一下socket的相关内容&#xff0c;但是没想到引入外部库还有这么多门道。 根据维基百科定义&#xff1a;一个现代编译器的主要工作流程如下&#xff1a;源代码&#xff08;source code&#xff09;→ 预处理器&#xff08;preprocessor&#xff09;→ 编译器…

爆破linux密码 $6$3uwqC9JI$d9iPRmTDAoXs/IbsplxS3iyeErHqw7fUycacXNHyZk1UCSwFEydl515/zXN7OEwHnyUaqYcNG...

1 #!/usr/bin/env python2 # -*- coding:UTF-8 -*-3 4 import crypt5 import sys6 7 # 哈希密码的前两位就是盐的前两位&#xff0c;这里我们假设盐只有两位。8 # 程序分两部分&#xff0c;一部分是打开字典&#xff0c;另一部分是哈希匹配密码9 10 #standard DES, two salt 1…

[G星计划]--项目开发总结

第一轮&#xff1a;Dr.Mech 参加了为期7天的第一轮DEMO竞赛&#xff0c;最佳团队&#xff0c;总结一下开发过程中的一些要点。 问题&#xff1a; 关于项目时间安排&#xff0c;由于项目核心代码量并不算太多&#xff0c;所以前几天还是比较从容的&#xff0c;不过这也导致许多…

使用BeanUitls提高对象拷贝效率

首先来创建两个bean 注&#xff1a;一定要有set/get方法,成员变量必须要同名 public class User1 {String name;String password;String phone; /**省略get/set方法**/ } public class User2 {String name;String password;String phone; /**省略get/set方法**/ } 1.Spring的Be…

机器字长、存储字长、指令字长

机器字长&#xff1a;CPU一次能处理数据的位数&#xff0c;一般等于CPU的寄存器位数。 存储字长&#xff1a;存储器中一个存储单元(存储地址)所存储的二进制代码的位数&#xff0c;即存储器中的MDR的位数。 指令字长&#xff1a;计算机指令字的位数。

var let this的区别

var xx; function test(){ var aa; //声明一let bb; //声明二this.cc; //声明三 //声明一局部代码块{let dd; //声明四 } }那么&#xff0c;这三种方式有什么区别呢&#xff1f; 区别在于作用域不…

在2020年学习cocos游戏引擎

常用链接 Cocos2d-x 用户手册 参考书目 《Cocos2d-X游戏开发实战精解》 《我所理解的Cocos2d-x》 《Effective C》中文版第三版 环境搭建 macOS 10.15.6 Xcode 11.5 cocos2d-x 3.17.2 cmake 3.17.3 创建工程 采用cocos2d-x 3.17版本可直接通过cocos console创建&#xf…

gdb调试程序

编译的时候需要加上 -g 选项。 gcc -o program -g main.c 执行的时候用 gdb 执行。 gdb ./program 常用命令 l 5, 列出从5行开始的前10行代码 b 6, b fun , 设置断点&#xff0c;参数可以是代码行号或者函数名 r , 运行 p, 运行暂停时&#xff0c;可以用 p expression 输出表…

[源码学习]--UGUI

学习参考 从bitbucket上获取uGUI 2019.1源码 UGUI内核大探究 事件系统 UnityEngine.UI/EventSystem/EventSystem.cs private List<BaseInputModule> m_SystemInputModules new List<BaseInputModule>(); // 系统输入模块列表 private BaseInputModule m_Curr…

PureMVC在Unity游戏开发中的应用

作为开发人员&#xff0c;我们都想写出优雅的代码&#xff0c;可又苦于自身能力不知该如何下手&#xff0c;而框架的作用正在与能够让你规范的去开发。 之前写Web的时候&#xff0c;总被要求采用MVC架构&#xff0c;的确非常好用&#xff0c;也从来没有质疑过这种架构的好与不好…

Lua热更新学习

在游戏开发中&#xff0c;常采用Lua进行热更新&#xff0c;本文主要记录lua学习过程中的知识点 Lua框架选择腾讯维护的xLua进行学习 lua语法 Lua中文文档 常用tips // 无需结尾;分号 // nil 表示回收内存 // type() 获取类型 // 单行注释 -- // 多行注释 --[[]]-- // 字符串…

3栏布局技巧

流体布局 主要内容无法优先加载&#xff0c;影响用户体验 html结构&#xff0c;left,right&#xff0c;center&#xff0c;主要内容无法优先加载 <div class"container1"><div class"col_left">left</div> <div class"col_r…