标题:看看这种图的遍历...
取消只看楼主
haroldi
Rank: 1
等 级:新手上路
帖 子:158
专家分:0
注 册:2006-7-22
 问题点数:0 回复次数:2 
看看这种图的遍历...

觉得我这种方法还比较清晰易懂,虽然算不上哪种方法,但确实每个点都能遍历到.
实际上有怎么弄得吗......

typedef struct Arcs{
int AdjVex;
int Weight;
struct Arcs *NextArc;
}ArcType;
typedef struct{
int Vex[MaxVex];
ArcType *FirstArc[MaxVex];
int VexNum;
}ALGraph;
//-----------------------------------------------------------------------
void GraphTraver(ALGraph AG) //图的遍历;
{
int i,Visited[MaxVex] = {0};
ArcType *p = NULL;
for(i = 1;i <= AG.VexNum;i++)
{
if(Visited[i] != 1)
{
printf("%2d ",AG.Vex[i]);
Visited[AG.Vex[i]] = 1;
}
p = AG.FirstArc[i];
while(p != NULL)
{
if(Visited[p->AdjVex] != 1)
{
printf("%2d ",p->AdjVex);
Visited[p->AdjVex] = 1;
}
p = p->NextArc;
}
}
}
//-----------------------------------------------------------------------

搜索更多相关主题的帖子: 遍历 易懂 
2006-12-14 23:25
haroldi
Rank: 1
等 级:新手上路
帖 子:158
专家分:0
注 册:2006-7-22
得分:0 
typedef struct{
int Vex[MaxVex];
ArcType *FirstArc[MaxVex];
int VexNum;
}ALGraph;

只是定义的不同,我只是想把顶点数量VexNum加进去.和下面的类似.
typedef struct{
int Vex;
ArcType *FirstArc;
}ALGraph[MaxVex];
...
p = AG[i].FirstArc;

请斑斑指导一下.

Do people want thick road ...
2006-12-15 00:46
haroldi
Rank: 1
等 级:新手上路
帖 子:158
专家分:0
注 册:2006-7-22
得分:0 
哦,是这样.多谢了!

Do people want thick road ...
2006-12-15 09:41



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-109588-1-1.html




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

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