单源点最短路径Dijkstra方法实现

2024-08-21 05:48

本文主要是介绍单源点最短路径Dijkstra方法实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、数据集形式

这里写图片描述
其中:6105(节点个数) 7035(边数)
0(id) 1609(起始边) 1622(终边) 57.403187(权重)

二、数据集

数据集下载链接

三、实现代码

// Dijkstra.cpp : Defines the entry point for the console application.
//#include "stdafx.h"
#include "time.h"
#include <fstream>
#include<iostream>
#include <stack>
#include<algorithm>
using namespace std;//#define PATH "E://dataset//MapSet//MinCreateTree//Testnew.txt"//#define PATH "E://dataset//MapSet//MinCreateTree//Ol.txt"
//#define PATH "E://dataset//MapSet//MinCreateTree//TGRoad.txt"
//#define PATH "E://dataset//MapSet//MinCreateTree//California.txt"
//#define PATH "E://dataset//MapSet//MinCreateTree//San.txt"
//#define PATH "E://dataset//MapSet//MinCreateTree//NA.txt"
int nodeNumber;
int edgeNumber;
class CWeightSort {
public:int value;double weight;CWeightSort *before;CWeightSort *next;
};
class CTreeNode
{
public:CTreeNode(){}~CTreeNode() {}int value;double  weight;CTreeNode *next;
};
class CTree
{
public:CTree() {smallWeigth = NULL;}~CTree() {}int value;CTreeNode *next;CTree *before;CWeightSort *smallWeigth;bool state;
};
CTree* createTree(char* filename)
{CTree *tree;ifstream ReadFile;int temp;ReadFile.open(filename, ios::in);//ios::in 表示以只读的方式读取文件ReadFile >> nodeNumber;//第一个字符是数组长度ReadFile >> edgeNumber;tree = new CTree[nodeNumber];//为树赋初值for (int i = 0; i < nodeNumber; i++){tree[i].next = NULL;tree[i].value = i;tree[i].state = true;tree[i].before = NULL;}tree[0].smallWeigth = new CWeightSort;tree[0].smallWeigth->weight = 0;CTreeNode *nt;while (!ReadFile.eof())            //按空格读取,遇到空白符结束{nt = new CTreeNode();       //读出的数据新建一个节点ReadFile >> temp;ReadFile >> temp;ReadFile >> (nt->value);ReadFile >> (nt->weight);nt->next = tree[temp].next;tree[temp].next = nt;}return tree;
}class CQueue {                                  //一个保持队形的队列结构
public:CQueue() {que = new CWeightSort();que->next = NULL;}void Add(CWeightSort *nq) {//将新节点按顺序插入到队列上CWeightSort *q = que;while (q->next != NULL){if (nq->weight < q->next->weight){q->next->before = nq;nq->next = q->next;nq->before = q;q->next = nq;break;}q = q->next;}if (q->next == NULL){nq->next = q->next;nq->before = q;q->next = nq;}}CWeightSort * del(CWeightSort *nq){nq->before->next = nq->next;if (nq->next != NULL)nq->next->before = nq->before;return nq;}bool empty(){if (que->next == NULL)return true;return false;}CWeightSort *que;
};
CTree* Dijkstra(CTree *tree)
{CQueue myQue;CWeightSort *myi=new CWeightSort;myi->value = 0;myi->before = NULL;myQue.Add(myi);CWeightSort *nt=NULL;while (!myQue.empty()){nt = myQue.del(myQue.que->next);//cout << nt->value << "(" << nt->weight << ")" << " ";//标记这个节点为已经访问状态tree[nt->value].state = false;CTreeNode *p = tree[nt->value].next;while (p!=NULL){//链接的节点已经完成,不做任何改变if (tree[p->value].state){//链接的节点,没有更小的值if (tree[p->value].smallWeigth == NULL){CWeightSort *node = new CWeightSort;node->value = p->value;node->weight = tree[nt->value].smallWeigth->weight + p->weight;tree[p->value].smallWeigth = node;tree[p->value].before = &tree[nt->value];myQue.Add(node);}//链接的节点,存在更小的值else if (tree[p->value].smallWeigth->weight>tree[nt->value].smallWeigth->weight+p->weight){CWeightSort *node=myQue.del(tree[p->value].smallWeigth);node->value = p->value;node->weight = tree[nt->value].smallWeigth->weight + p->weight;tree[p->value].smallWeigth = node;tree[p->value].before = &tree[nt->value];myQue.Add(node);}}p = p->next;}}return &tree[nt->value];
}
int main()
{//构建图CTree *tree = createTree(PATH);double useTime;clock_t start, finish;start = clock();//算法CTree* m=Dijkstra(tree);finish = clock();useTime = (double)(finish - start) / CLOCKS_PER_SEC * 1000;printf("%f 毫秒\n", useTime);system("pause");return 0;
}

这篇关于单源点最短路径Dijkstra方法实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092295

相关文章

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte