| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1520 人关注过本帖
标题:图的最短路径问题
只看楼主 加入收藏
queyapa
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2006-4-5
收藏
 问题点数:0 回复次数:5 
图的最短路径问题

请问一下 在 完成最短算法后 怎么样输出最短路径 多经过的点啊
急 急 急

搜索更多相关主题的帖子: 路径 
2006-06-14 07:40
乌鸦丘比特
Rank: 1
等 级:新手上路
威 望:2
帖 子:625
专家分:0
注 册:2004-7-19
收藏
得分:0 

如果你是用dijkstra算法的话,在每次扩展点的时候记录这个点的在最短路上的前驱点,最后逆向找最短路就可以了


我喜欢创造,一只扑腾着翅膀向天空飞翔的乌鸦
2006-06-14 07:48
queyapa
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2006-4-5
收藏
得分:0 

如果用FLOYD算法 呢

2006-06-14 07:58
乌鸦丘比特
Rank: 1
等 级:新手上路
威 望:2
帖 子:625
专家分:0
注 册:2004-7-19
收藏
得分:0 
floyd算法的话我目前想到的需要三维数组
假设有MAX个节点

flag[MAX][MAX][MAX];flag[某路径起始点标号][该路径终止点标号][T]该最短路上T的后继节点(如果T不在该路上可以特殊处理,比如标记为-1)具体处理在floyd扩展的时候很容易做到,

当最大路过标号为k时,如果该路径不过k,显然不用做任何修改,如果过的话,就把k的前驱节点和k本身的信息修改一下就可以了

我喜欢创造,一只扑腾着翅膀向天空飞翔的乌鸦
2006-06-14 08:10
乌鸦丘比特
Rank: 1
等 级:新手上路
威 望:2
帖 子:625
专家分:0
注 册:2004-7-19
收藏
得分:0 
不好意思,上面那楼说的方法应该错D

我喜欢创造,一只扑腾着翅膀向天空飞翔的乌鸦
2006-06-14 18:31
cordier
Rank: 2
等 级:论坛游民
威 望:1
帖 子:449
专家分:14
注 册:2006-2-9
收藏
得分:0 

找一本图论的书看吧!


2006-06-15 10:46
快速回复:图的最短路径问题
数据加载中...
 
   



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

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