C语言最短路径问题

C语言最短路径问题
#include "datastru.h"
#include
#include
#define MAX 10000

MGRAPH create_mgraph(){

int i, j, k, h;
MGRAPH mg;

mg.kind = 3;
printf("\n\n输入顶点数和边数(用逗号隔开) : ");
scanf("%d,%d", &i,&j);
mg.vexnum = i;
mg.arcnum = j;
fflush(stdin);
for(i = 0; i < mg.vexnum; i++)
{ printf("输入顶点 %d 的值 : ",i + 1);
scanf("%d", &mg.vexs[i]);
fflush(stdin);}
for(i = 0; i < mg.vexnum; i++)
for(j = 0; j < mg.vexnum; j++)
mg.arcs[i][j] = MAX;
for(k = 1; k <= mg.arcnum; k++)
{ printf("输入第 %d 条边的起始顶点和终止顶点(用逗号隔开): ",k);
scanf("%d,%d",&i,&j);
fflush(stdin);
while(i < 1 || i > mg.vexnum || j < 1 || j > mg.vexnum)
{ printf("输入错,重新输入: ");
scanf("%d,%d", &i, &j);}
printf("输入此边权值 : ");
scanf("%d", &h);
mg.arcs[i - 1][j - 1] = h;}
return mg;
}

main()
{
MGRAPH mg;
int cost[MAXLEN][MAXLEN];
int path[MAXLEN], s[MAXLEN];
int dist[MAXLEN];
int i, j, n, v0, min, u;

printf("\n求有向图单源点最短路径\n");
mg = create_mgraph();
printf("\n\n起始顶点为 : ");
scanf("%d", &v0);
v0 --;
n = mg.vexnum;
for(i = 0; i < n; i++)
{for(j = 0; j < n; j++)
cost[i][j] = mg.arcs[i][j];
cost[i][i] = 0;}
for(i = 0; i < n; i++)
{dist[i] = cost[v0][i];
if(dist[i] < MAX && dist[i] > 0)
path[i] = v0;}
for(i = 0; i < n; i++)
s[i] = 0;
s[v0] = 1;
for(i = 0; i < n; i++)
{ min = MAX ;
u = v0;
for(j = 0; j < n; j++)
if(s[j] == 0 && dist[j] < min)
{min = dist[j];
u = j;}
s[u] = 1;
for(j = 0; j < n; j++)
if(s[j] == 0 && dist[u] + cost[u][j] < dist[j])
{dist[j] = dist[u] + cost[u][j];
path[j] = u;}
}
for(i = 0; i < n; i++)
if(s[i] == 1)
{u = i;
while(u != v0)
{printf("%d <- " , u + 1);
u = path[u];}
printf("%d ", u + 1);
printf(" d = %d\n", dist[i]);
}
else
printf("%d <- %d d= MAX\n ", i + 1, v0 + 1);
printf("\n\n");
}
 

文章来源:

非常夏日毕业设计  www.bysjdz.com  毕业设计 毕业论文  论文定做 免费论文  开题报告  文献综述  外文翻译  毕业设计定做  计算机毕业设计  计算机毕业论文 计算机外文翻译

找吧!毕业设计  www.zhaobysj.com 毕业设计 毕业论文 论文定做 免费论文 开题报告  文献综述 外文翻译  毕业设计定做  计算机毕业设计   计算机毕业论文 计算机外文翻译

转载于:https://www.cnblogs.com/hotsummer/archive/2010/12/27/1918290.html

你可能感兴趣的:(C语言最短路径问题)