当前位置: 首页 > news >正文

科技创业定西seo排名

科技创业,定西seo排名,自助定制网站开发公司,外贸公司用什么建网站数据结构–最短路径 Dijkstra算法 Dijkstra算法 计算 b e g i n 点到各个点的最短路 \color{red}计算\ begin\ 点到各个点的最短路 计算 begin 点到各个点的最短路 如果是无向图,可以先把无向图转化成有向图 我们需要2个数组 final[] (标记各顶点是否已…

数据结构–最短路径 Dijkstra算法

Dijkstra算法

计算  b e g i n 点到各个点的最短路 \color{red}计算\ begin\ 点到各个点的最短路 计算 begin 点到各个点的最短路

如果是无向图,可以先把无向图转化成有向图

我们需要2个数组
final[] (标记各顶点是否已找到最短路径)与 dis[] (最短路径⻓度)数组

Dijkstra算法是一种用于寻找图中最短路径的算法,它的步骤如下:

  1. 初始化:将起始节点的最短路径设置为0,其他节点的最短路径设置为正无穷大。
  2. 选取最短路径最小的节点作为当前节点。
  3. 更新当前节点的邻居节点的最短路径:如果通过当前节点到达邻居节点的路径比邻居节点当前的最短路径更短,则更新邻居节点的最短路径。
  4. 标记当前节点为已访问(已经找到 b e g i n begin begin 到该点的最短路)。
  5. 重复步骤2 → \to 4,直到所有节点都被访问过或者没有可达到的节点。
  6. 根据最短路径和前驱节点构建最短路径树或者路径数组。

以上就是Dijkstra算法的基本步骤。在实际应用中,可以使用优先队列来选取最短路径最小的节点,以提高算法的效率 (堆Dijkstra)。

V0到V2 的最短(带权)路径⻓度为:dist[2] = 9
通过 path[ ] 可知,V0到V2 的最短(带权)路径:
v 0 → v 4 → v 1 → v 2 v_0 \to v_4 \to v_1 \to v_2 v0v4v1v2

Dijkstra算法的时间复杂度

时间复杂度: O ( n 2 ) 即 O ( ∣ V ∣ 2 ) O(n^2)即O(|V|^2) O(n2)O(V2)

代码实现

int g[N][N]; // 存储每条边
int dist[N]; // 存储1号点到每个点的最短距离
bool st[N]; // 存储每个点的最短路是否已经确定
//时间复杂是 O(n2+m), n 表示点数,m 表示边数
// 求1号点到n号点的最短路,如果不存在则返回-1
int dijkstra()
{memset(dist, 0x3f, sizeof dist);dist[1] = 0;for (int i = 0; i < n - 1; i++){int t = -1; // 在还未确定最短路的点中,寻找距离最⼩的点for (int j = 1; j <= n; j++)if (!st[j] && (t == -1 || dist[t] > dist[j]))t = j;// ⽤t更新其他点的距离for (int j = 1; j <= n; j++)dist[j] = min(dist[j], dist[t] + g[t][j]);st[t] = true;}if (dist[n] == 0x3f3f3f3f)return -1;return dist[n];
}

负权值带权图问题,Dijkstra不可用

负权值带权图问题, D i j k s t r a 不可用!!! \color{red}负权值带权图问题,Dijkstra不可用!!! 负权值带权图问题,Dijkstra不可用!!!

事实上 V 0 V_0 V0 V 2 V_2 V2 的最短带权路径⻓度为 5
结论:Dijkstra 算法不适⽤于有负权值的带权图

http://www.yayakq.cn/news/435134/

相关文章:

  • 怎样做网站文件验证缺乏门户网站建设
  • 建设商城网站公司百度百科wordpress建站赚钱
  • 太原市给企业做网站如何选择一个好的优质网站建设公司
  • 分析电子商务网站建设需求教案asp网站设计
  • flash 企业网站 源码wordpress颜色
  • 网站建设销售专业术语做素材网站赚钱吗
  • 数字媒体应用 网站开发安徽省造价信息网官网
  • 网站开发维护的工作职责以下软件中用来制作网页的有
  • 信用网站建设意义手机工信部网站备案查询
  • 河南住房和城乡建设厅网站首页生物制药公司网站模板
  • 深圳网站设计哪好深圳高端网站建设多少钱
  • 功能型企业网站有哪些手把手做网站页面
  • 江门网站关键词推广客户管理系统排名
  • 怎么在淘宝上做网站浙江十大外贸公司排名
  • 石景山老山网站建设WordPress自定义信息登记
  • 12380网站建设百度里面企业网站怎么建设
  • 重庆网站建设哪家强wordpress网站打开卡
  • 沈阳网站建设小志手机站制作的网站架构
  • 网站的建设成本网站优化推广平台
  • 做图片格式跟尺度用哪个网站好酷家乐线下培训班
  • 南京seo建站wordpress证书关闭
  • 做网站都需要什么工具wordpress文字替换
  • 周村网站建设zac博客seo
  • 做投票的网站书画网站 建站
  • 提供有经验的网站建设公司建设网站怎么作账
  • crm系统网站酒店软装设计公司官网
  • 网站的建站流程旅游网站建设方案的总结
  • 吴江区桃源镇做网站告诉你做网站需要多少钱
  • 襄汾县住房和建设局网站网站图片分辨率尺寸
  • 西安网站建设设计做商业网站需要注册公司吗