| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 6755 人关注过本帖, 1 人收藏
标题:利用Dijkstra算法实现最短路径搜索
只看楼主 加入收藏
120329
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2005-7-1
收藏
得分:0 
还有改成10个节点得话,还要改那些东西啊
2005-07-01 21:02
stkamen
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2005-7-1
收藏
得分:0 
改10结点就是改图中顶点的初始化那一步

2005-07-03 17:01
daiqinlin
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2005-10-12
收藏
得分:0 
[原创]

利用Dijkstra算法实现最短路径搜索 的程序中, 我怎么运行不出来呢? 电脑显示错误:f:\vc练习\lin.cpp(52) : error C2065: 'clrscr' : undeclared identifier f:\vc练习\lin.cpp(53) : error C2065: 'malloc' : undeclared identifier f:\vc练习\lin.cpp(68) : error C2065: 'getch' : undeclared identifier f:\vc练习\lin.cpp(68) : warning C4508: 'main' : function should return a value; 'void' return type assumed 执行 cl.exe 时出错.

lin.exe - 1 error(s), 0 warning(s)

[此贴子已经被作者于2005-10-12 17:31:01编辑过]

2005-10-12 17:22
牛虻
Rank: 1
等 级:新手上路
威 望:1
帖 子:472
专家分:0
注 册:2004-10-1
收藏
得分:0 

请用TC或Wintc编译运行


土冒
2006-11-06 20:10
热情依然
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:22
帖 子:715
专家分:0
注 册:2005-4-5
收藏
得分:0 
哈哈,这个程序不是用标准C++写的

c++/C + 汇编 = 天下无敌
2006-11-07 16:06
Liming_686
Rank: 1
等 级:新手上路
帖 子:64
专家分:0
注 册:2006-4-9
收藏
得分:0 
谢了,享受一下!!!!
2007-01-03 10:14
Liming_686
Rank: 1
等 级:新手上路
帖 子:64
专家分:0
注 册:2006-4-9
收藏
得分:0 

支持一下.

2007-01-03 10:21
soft_wind
Rank: 3Rank: 3
等 级:新手上路
威 望:8
帖 子:1430
专家分:0
注 册:2006-4-5
收藏
得分:0 

[CODE]#include "stdio.h"
#include "string.h"
#define MAXINT 0xfff
#define MAXSIZE 100
typedef struct
{
char name[20];
int value;
}infotype;
typedef struct ArcNode
{
int weight;
infotype *info;
}ArcNode;
typedef struct
{
char v[MAXSIZE];
ArcNode arc[MAXSIZE][MAXSIZE];
int vertexnum,arcnum;
}Graph;
Graph g;
int Locate(char ch)
{
int i;
for(i=0;g.v[i]!=ch;i++);
return i;
}
void Dijkstra(int posObt,int cost[])
{
int i,j,w,sum,temp;
bool set[MAXSIZE+1];
memset(set,false,sizeof(set));
for(i=0;i<g.vertexnum;i++)
{
cost[i]=g.arc[posObt][i].weight;
}
set[posObt]=true;
for(i=0;i<g.vertexnum;i++)
{
temp=MAXINT;
for(j=0;j<g.vertexnum;j++)
if(set[j]==false&&cost[j]<temp)
{
temp=cost[j];
w=j;
}
set[w]=true;
for (j=0;j<g.vertexnum;j++)
if (set[j]!=true)
{
sum=cost[w]+g.arc[w][j].weight;
if (sum<cost[j])
cost[j]=sum;
}
}
}
int main(void)
{
int i,j,pos_x,pos_y,posObt,wei;
int cost[MAXSIZE+1];
char start[2],end[2];
char search;
printf("Please input the number of the vertexs and the arcs:\n");
do{
scanf("%d%d",&g.vertexnum,&g.arcnum);
if(g.vertexnum>100)
printf("The number is too large.Please input a smaller number:\n");
}while(g.vertexnum>100);
for(i=0;i<g.vertexnum;i++)
for(j=0;j<g.vertexnum;j++)
{
g.arc[i][j].weight=MAXINT;
g.arc[i][j].info=NULL;
}
printf("Now input the vertex:\n");
fflush(stdin);
for(i=0;i<g.vertexnum;i++)
g.v[i]=getchar();
printf("Now input the arcs:(for example:a b 10)\n");
for(i=0;i<g.arcnum;i++)
{
scanf("%s%s%d",start,end,&wei);
pos_x=Locate(start[0]);
pos_y=Locate(end[0]);
g.arc[pos_x][pos_y].weight=wei;
}
fflush(stdin);
printf("Now input the vertex you want to search its minimal path to other vertexs:\n");
search=getchar();
posObt=Locate(search);
Dijkstra(posObt,cost);
for(i=0;i<g.vertexnum;i++)
if(i!=posObt)
{
printf("%c->%c:%d\n",g.v[posObt],g.v[i],cost[i]);
}
return 0;
}[/CODE]

floyd算法虽然算的是全源最短路径,但写起来就更简单了,就不详细写了,
只写个大概:
void Floyd(Fl[][],Edge[][],n)
{ for ( i = 1; i <= n; i++ )
for ( j = 1; j<=n; j++ )
Fl[i][j] = Edge[i][j] ;
for ( k = 1; k <= n; k++ )
for ( i = 1; i <= n; i++ )
for ( j = 1; j <=n; j++ )
if ( Fl[i][k] + Fl[k][j] < Fl[i][j] )
Fl[i][j] = Fl[i][k] + Fl[k][j] ;
}


对不礼貌的女生收钱......
2007-01-03 12:58
gxppa2006
Rank: 1
等 级:新手上路
帖 子:178
专家分:0
注 册:2007-2-27
收藏
得分:0 
呵呵  写的好  顶一下

临渊羡鱼,不如退而结网!
2007-06-06 19:29
枫林晴雨
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2007-6-14
收藏
得分:0 
回复:(牛虻)利用Dijkstra算法实现最短路径搜索
xiexie le  
2007-06-16 20:34
快速回复:利用Dijkstra算法实现最短路径搜索
数据加载中...
 
   



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

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