| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 361 人关注过本帖
标题:新手求助 迪杰斯特拉算法
只看楼主 加入收藏
波妞
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2012-12-26
结帖率:0
收藏
已结贴  问题点数:20 回复次数:4 
新手求助 迪杰斯特拉算法
#include<stdio.h>
#include<stdlib.h>
#define INFINITY 1000000000
#define MAX 10 //图中最大顶点个数
typedef struct MGraph
{
char vexs[MAX];
int arcs[MAX][MAX];
int vexnum, arcnum;
}MGraph;
//定位顶点
int LocateVex(MGraph G,char v)
{
int i;
for(i=0;i<G.vexnum;i++)
if(v==G.vexs[i])
return i;
return -1;
}
//建立邻接矩阵存储的有向网
void CreatedMGraph(MGraph &G)
{
int i,j,v;
char v1,v2;
int weights;
printf("请输入顶点数和边数:");
scanf("%d%d",&G.vexnum,&G.arcnum);
for(i=0;i<G.vexnum;i++)
for(j=0;j<G.vexnum;j++)
G.arcs[i][j]=INFINITY;
printf("请输入顶点:");
for(v=0;v< G.vexnum;v++)
{
G.vexs[v]=getchar();
}
printf("请输入边及边的权值:");
for(v=0;v<G.arcnum;v++)
{
scanf("%c%c",&v1,&v2);
scanf("%d",&weights);
i=LocateVex(G,v1);
j=LocateVex(G,v2);
G.arcs[i][j]=weights;
}
}
//利用Dijkstra算法求有向网G的从顶点v0到其他各顶点的最短路径
void ShortestPath_DIJ(MGraph G, int v0,  int P[MAX][MAX],int D[MAX])
{
int v,i;
int w,j;
int final[MAX];//到顶点v最短路径是否找到
//初始化
for (v=0; v<G.vexnum; ++v)
{
final[v]=0;
D[v]=G.arcs[v0][v];
for (i=0; i<G.vexnum; ++i)
{
P[v][i]=0; //初始路径为空
}
if (D[v]<INFINITY)
{
P[v][v0]=1;
P[v][v]=1;
}
} //for
D[v0]=0;
final[v0]=1;
//下面是每次求得v0到某个v顶点的最短路径,并加v到S集
for (i=1; i<G.vexnum; ++i)
{
int min=1000;
for (j=0; j<G.vexnum;++j) //求v0到w的最短路径
{
if(!final[j])
if(D[j]<min)
{
v=j;
min=D[j];
}
}
final[v]=1;
for (w=0; w<G.vexnum; ++w) //更新到T中顶点的最短路径
if (!final[w] && (min+G.arcs[v][w]<D[w] ))
{
D[w]=min+G.arcs[v][w];
for(j=0;j<G.vexnum;++j)
P[w][j]=P[v][j];
P[w][w]=1;
}
}
for (v=0; v<G.vexnum; ++v)
{
for(i=0;i<G.vexnum;i++)
{
if(P[v][i])
printf("%c",G.vexs[i]);
}
printf("\n");
}
}
void main()
{
MGraph G;
int v,i;
int P[MAX][MAX];//最短路径数组
int D[MAX]; //最短路径长度
CreatedMGraph(G);
printf("%d,%d",G.vexnum,G.arcnum);
for (v=0; v<G.vexnum; ++v)
{
printf("%c",G.vexs[v]);
for(i=0;i<G.vexnum;i++)
{
printf("%c",G.arcs[v][i]);
}
}
printf("请输入所求最短路径的顶点:");
scanf("%c",&v);
getchar();
i=LocateVex(G,v);
ShortestPath_DIJ(G,i,P,D);
}

不知道哪里错了
求帮助
搜索更多相关主题的帖子: void include return 
2012-12-26 13:02
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:7 
给个输入输出示例吧


[fly]存在即是合理[/fly]
2012-12-26 13:31
daniel_
Rank: 5Rank: 5
等 级:职业侠客
帖 子:212
专家分:307
注 册:2012-11-13
收藏
得分:7 
新手求助!!!!!!!!!
楼主,你这个问题是什么?
2012-12-26 15:13
波妞
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2012-12-26
收藏
得分:0 
回复 3楼 daniel_
求最短路径
2012-12-27 13:11
a151141
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:1
帖 子:197
专家分:680
注 册:2012-10-19
收藏
得分:7 
  看的头疼

世界上幸福的事就是抓到一只羊,更幸福的事就是抓到两只羊……
2012-12-27 13:44
快速回复:新手求助 迪杰斯特拉算法
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.039245 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved