数据结构-Djikstra算法(C语言版)

cpp 复制代码
#include<stdio.h>
#define MAX 100
typedef struct Mgraph{
	char vertex[MAX];
	int arcs[MAX][MAX];
	int vexnum,arcnum;
}Mgraph;

int Locate(Mgraph G,char v)
{
	int i;
	for(i=0;i<G.vexnum;i++){
		if(G.vertex[i]==v){
			return i;
		}
	}
	return -1;
}

void Dijkstra(Mgraph G,char v,int n)
{
	int D[MAX],path[MAX],T[MAX];
	int i,j,m,k,min=9999;
	k = Locate(G,v);
	if(k==-1)
		return;
	for(i=0;i<G.vexnum;i++){
		D[i] = G.arcs[k][i];
		T[i] = 0;
		if(D[i]<min){
			path[i] = k; 
		}
		else
			path[i] = 0;
	}
	T[k]  = i;
	for(m=1;m<G.vexnum;i++){
		min = 9999;
		j = -1;
		for(i=0;i<G.vexnum;i++){
			if(T[i]==0&&D[i]<min){
				j = i;
				min = D[i];
			}
		}
		if(j==-1)
			break;
		else{
			T[j] = 1;
			for(i=0;i<G.vexnum;i++){
				if(T[i]==0&&D[j]+G.arcs[j][i]<D[i]){
					D[i] = D[j] + G.arcs[j][i];
					path[i] = j;
				}
			}
		}
	}    
}

int main()
{
 	
	return 0;
}
相关推荐
Fms_Sa几秒前
分治法—最大子段问题
算法·c#
love_muming4 分钟前
从 ArrayList 到 LinkedList:Java 集合中数组与链表的深度对比
java·数据结构·链表
Galerkin码农选手5 分钟前
awq_marlin和gptq_marlin量化算法简要介绍
算法
buhuizhiyuci6 分钟前
【算法篇】动态规划——斐波那契数列模型
算法·动态规划
棱镜研途7 分钟前
学习笔记丨模式识别与机器学习5大核心赛道解析(IC-IPPR 2026)
人工智能·神经网络·算法·机器学习·模式识别·学术会议·智能计算
SuperHeroWu717 分钟前
【算法】逻辑回归虽然名字中有“回归“,但通常用于二分类任务。如何理解学习?
算法·回归·逻辑回归·二分类任务
gCode Teacher 格码致知21 分钟前
Python教学:十六进制编码的显示方法-由Deepseek产生
开发语言·python·算法
05候补工程师21 分钟前
【408数据结构】核心考点:图(Graph)精炼笔记与算法直觉
数据结构·经验分享·笔记·考研·算法·图论
并不喜欢吃鱼21 分钟前
从零开始 C++------ 十四【C++ 数据结构】unordered_map/unordered_set 全解析:从使用到底层模拟实现
开发语言·数据结构·c++
靠沿22 分钟前
【动态规划算法】专题三——简单多状态dp问题
算法·动态规划