新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     >>计算机科学论坛<<     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 研友的交流园地,讨论关于计算机考研的方方面面。
    [返回] 计算机科学论坛计算机理论与工程『 计算机考研交流 』 → 今年北大一道本科作业 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 6073 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 今年北大一道本科作业 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     mxf3306 帅哥哟,离线,有人找我吗?
      
      
      等级:大三(研究MFC有点眉目了!)
      文章:112
      积分:823
      门派:XML.ORG.CN
      注册:2006/7/6

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给mxf3306发送一个短消息 把mxf3306加入好友 查看mxf3306的个人资料 搜索mxf3306在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看mxf3306的博客楼主
    发贴心情 今年北大一道本科作业

    6.2  Dijstra算法是“求某点到所有点的最短距离”,请编写算法“求某点到所有点的次短距离”(第二最短路径)。
    想了很久,无从下手。关键在于这个次短距离没有一个最优的子结构,次短距离中包含的不一定是次短距离之和,也可能是最短距离之和。而且这些单源次短路径构成的甚至可能不是一颗树。
    不知有没有人有比较好的思路 。
    顺便提一下:求一般图中两点间最长距离的算法,尽管看起来和求最短距离的问题相似。但据算法导论,却是一个NPC问题。所以大家不要看轻了这道作业题。

       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/11/6 22:00:00
     
     carroty 帅哥哟,离线,有人找我吗?
      
      
      等级:大四(GRE考了1600分!)
      文章:153
      积分:1257
      门派:IEEE.ORG.CN
      注册:2006/4/4

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给carroty发送一个短消息 把carroty加入好友 查看carroty的个人资料 搜索carroty在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看carroty的博客2
    发贴心情 
    http://www.roboticfan.com/college/knowledge/200608/195.shtml

    算法介绍
    Dijkstra算法是由荷兰计算机科学家艾兹格·迪科斯彻发现的。算法解决的是有向图中最短路径问题。

    举例来说,如果图中的顶点表示城市,而边上的权重表示著城市间开车行经的距离。 Dijkstra算法可以用来找到两个城市之间的最短路径。

    Dijkstra算法的输入包含了一个有权重的有向图G,以及G中的一个来源顶点S。 我们以V表示G中所有顶点的集合。 每一个图中的边,都是两个顶点所形成的有序元素对。(u,v)表示从顶点u到v有路径相连。 我们以E所有边的集合,而边的权重则由权重函数w: E → [0, ∞]定义。 因此,w(u,v)就是从顶点u到顶点v的非负花费值(cost)。 边的花费可以想像成两个顶点之间的距离。任两点间路径的花费值,就是该路径上所有边的花费值总和。 已知有V中有顶点s及t,Dijkstra算法可以找到s到t的最低花费路径(i.e. 最短路径)。 这个算法也可以在一个图中,找到从一个顶点s到任何其他顶点的最短路径。

    算法描述
    这个算法是通过为每个顶点v保留目前为止所找到的从s到v的最短路径来工作的。初始时,源点s的路径长度值被赋为0(d[s]=0), 同时把所有其他顶点的路径长度设为无穷大,即表示我们不知道任何通向这些顶点的路径(对于V中所有顶点v除s外d[v]= ∞)。当算法结束时,d[v]中储存的便是从s到v的最短路径,或者如果路径不存在的话是无穷大。 Dijstra算法的基础操作是边的拓展:如果存在一条从u到v的边,那么从s到u的最短路径可以通过将边(u,v)添加到尾部来拓展一条从s到v的路径。这条路径的长度是d[u]+w(u,v)。如果这个值比目前已知的d[v]的值要小,我们可以用新值来替代当前d[v]中的值。拓展边的操作一直执行到所有的d[v]都代表从s到v最短路径的花费。这个算法经过组织因而当d[u]达到它最终的值的时候没条边(u,v)都只被拓展一次。

    算法维护两个顶点集S和Q。集合S保留了我们已知的所有d[v]的值已经是最短路径的值顶点,而集合Q则保留其他所有顶点。集合S初始状态为空,而后每一步都有一个顶点从Q移动到S。这个被选择的顶点是Q中拥有最小的d[u]值的顶点。当一个顶点u从Q中转移到了S中,算法对每条外接边(u,v)进行拓展。

    伪码
    在下面的算法中,u:=Extract_Min(Q)在在顶点集Q中搜索有最小的d[u]值的顶点u。这个顶点被从集合Q中删除并返回给用户。

    1  function Dijkstra(G, w, s)
    2     for each vertex v in V[G]                        // 初始化
    3           d[v] := infinity
    4           previous[v] := undefined
    5     d[s] := 0
    6     S := empty set
    7     Q := set of all vertices
    8     while Q is not an empty set                      // Dijstra算法主体
    9           u := Extract_Min(Q)
    10           S := S union {u}
    11           for each edge (u,v) outgoing from u
    12                  if d[v] > d[u] + w(u,v)             // 拓展边(u,v)
    13                        d[v] := d[u] + w(u,v)
    14                        previous[v] := u
    如果我们只对在s和t之间寻找一条最短路径的话,我们可以在第9行添加条件如果满足u=t的话终止程序。

    现在我们可以通过迭代来回溯出s到t的最短路径

    1 S := empty sequence
    2 u := t
    3 while defined u                                        
    4       insert u to the beginning of S
    5       u := previous[u]
    现在序列S就是从s到t的最短路径的顶点集.

    时间复杂度
    我们可以用大O符号将Dijkstra算法的运行时间表示为边数m和顶点数n的函数。

    Dijkstra算法最简单的实现方法是用一个链表或者数组来存储所有顶点的集合Q,所以搜索Q中最小元素的运算(Extract-Min(Q))只需要线性搜索Q中的所有元素。这样的话算法的运行时间是O(n2)。

    对于边数少于n2稀疏图来说,我们可以用邻接表来更有效的实现Dijkstra算法。同时需要将一个二叉堆或者斐波纳契堆用作优先队列来寻找最小的顶点(Extract-Min)。当用到二叉堆的时候,算法所需的时间为O((m+n)log n),斐波纳契堆能稍微提高一些性能,让算法运行时间达到O(m + n log n)。

    相关问题和算法
    在Dijkstra算法的基础上作一些改动,可以扩展其功能。例如,有时希望在求得最短路径的基础上再列出一些次短的路径。为此,可先在原图上计算出最短路径,然后从图中删去该路径中的某一条边,在余下的子图中重新计算最短路径。对于原最短路径中的每一条边,均可求得一条删去该边后子图的最短路径,这些路径经排序后即为原图的一系列次短路径。

    OSPF(open shortest path first, 开放最短路径优先)算法是Dijkstra算法在网络路由中的一个具体实现。

    与Dijkstra算法不同,Bellman-Ford算法可用于具有负花费边的图,只要图中不存在总花费为负值且从源点 s 可达的环路(如果有这样的环路,则最短路径不存在,因为沿环路循环多次即可无限制的降低总花费)。

    与最短路径问题有关的一个问题是旅行商问题(traveling salesman problem),它要求找出通过所有顶点恰好一次且最终回到源点的最短路径。该问题是NP难的;换言之,与最短路径问题不同,旅行商问题不太可能具有多项式时间算法。

    如果有已知信息可用来估计某一点到目标点的距离,则可改用A*算法,以减小最短路径的搜索范围。

    参考
    E. W. Dijkstra: A note on two problems in connexion with graphs. In: Numerische Mathematik. 1 (1959), S. 269–271
    Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, and Clifford Stein. Introduction to Algorithms, Second Edition. MIT Press and McGraw-Hill, 2001. ISBN 0262032937. Section 24.3: Dijkstra's algorithm, pp.595–601.

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/11/6 23:42:00
     
     mxf3306 帅哥哟,离线,有人找我吗?
      
      
      等级:大三(研究MFC有点眉目了!)
      文章:112
      积分:823
      门派:XML.ORG.CN
      注册:2006/7/6

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给mxf3306发送一个短消息 把mxf3306加入好友 查看mxf3306的个人资料 搜索mxf3306在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看mxf3306的博客3
    发贴心情 
    相关问题和算法
    在Dijkstra算法的基础上作一些改动,可以扩展其功能。例如,有时希望在求得最短路径的基础上再列出一些次短的路径。为此,可先在原图上计算出最短路径,然后从图中删去该路径中的某一条边,在余下的子图中重新计算最短路径。对于原最短路径中的每一条边,均可求得一条删去该边后子图的最短路径,这些路径经排序后即为原图的一系列次短路径。

    这应该就是关键了。我之前也想过这种方法,但感觉很麻烦,尤其是很难实现,而且效率也太差了点吧。

    而且,这个办法也有行不通的时候,如图,每条边的权为1,从v1到v2有两条最短路径,无论去掉哪条路径的哪条边,求出的子图的最短路径都将是另一条最短路径,而非次短路径。
    /o\  v1
    /    \
    o----o
    \    /
    \o/  v2

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/11/7 15:40:00
     
     carroty 帅哥哟,离线,有人找我吗?
      
      
      等级:大四(GRE考了1600分!)
      文章:153
      积分:1257
      门派:IEEE.ORG.CN
      注册:2006/4/4

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给carroty发送一个短消息 把carroty加入好友 查看carroty的个人资料 搜索carroty在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看carroty的博客4
    发贴心情 
    恩,可能确实有这样的问题.比较郁闷....
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/11/7 23:22:00
     
     mxf3306 帅哥哟,离线,有人找我吗?
      
      
      等级:大三(研究MFC有点眉目了!)
      文章:112
      积分:823
      门派:XML.ORG.CN
      注册:2006/7/6

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给mxf3306发送一个短消息 把mxf3306加入好友 查看mxf3306的个人资料 搜索mxf3306在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看mxf3306的博客5
    发贴心情 
    还有没有人在考虑这个问题。
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/11/15 17:01:00
     
     lilylily 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:6
      积分:84
      门派:XML.ORG.CN
      注册:2006/9/1

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给lilylily发送一个短消息 把lilylily加入好友 查看lilylily的个人资料 搜索lilylily在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看lilylily的博客6
    发贴心情 
    楼主可以把今年的本科生作业以及答案分析发给我吗?
    谢谢   邮箱lily830307@sina.com
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/12/4 11:52:00
     
     lilylily 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:6
      积分:84
      门派:XML.ORG.CN
      注册:2006/9/1

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给lilylily发送一个短消息 把lilylily加入好友 查看lilylily的个人资料 搜索lilylily在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看lilylily的博客7
    发贴心情 
    可以加个if条件判断一下,如果相同就删除另一条边,不过好像是太麻烦了一点
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/12/4 12:06:00
     
     afen_pku 帅哥哟,离线,有人找我吗?天蝎座1983-10-24
      
      
      等级:大二(研究C++)
      文章:21
      积分:214
      门派:XML.ORG.CN
      注册:2006/5/2

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给afen_pku发送一个短消息 把afen_pku加入好友 查看afen_pku的个人资料 搜索afen_pku在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看afen_pku的博客8
    发贴心情 
    楼主也可以给我一份吗?
    wodepku@163.com
    谢谢了
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/12/4 12:56:00
     
     lalala 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:1
      积分:61
      门派:XML.ORG.CN
      注册:2006/9/12

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给lalala发送一个短消息 把lalala加入好友 查看lalala的个人资料 搜索lalala在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看lalala的博客9
    发贴心情 
    我也想要一份,谢谢搂主和楼上的兄弟。cyff@163.com
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/12/5 15:22:00
     
     mxf3306 帅哥哟,离线,有人找我吗?
      
      
      等级:大三(研究MFC有点眉目了!)
      文章:112
      积分:823
      门派:XML.ORG.CN
      注册:2006/7/6

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给mxf3306发送一个短消息 把mxf3306加入好友 查看mxf3306的个人资料 搜索mxf3306在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看mxf3306的博客10
    发贴心情 
    作业网址如下:http://db.cs.pku.edu.cn/mzhang/ds/CSmaterial/,答案是没有的,只有北大本科生才拿得到。
    发到邮箱就免了吧,一个一个地发,到考研结束也发不完
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/12/5 17:59:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 计算机考研交流 』 的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/4/28 16:02:41

    本主题贴数10,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    2,695.313ms