POJ3311 Hie with the Pie(DP:TSP问题)

这是一篇关于如何使用动态规划解决图论中的经典问题——旅行商问题(TSP)的博客。通过POJ3311题目为例,介绍了如何结合Floyd算法求解每对城市间的最短路径,并定义d[i][s]数组来表示在当前城市i且已访问过s集合城市的情况下,找到的最短路径。状态转移方程关键在于寻找合适的中间点以缩短总距离,同时注意有向图的特性。
摘要由CSDN通过智能技术生成

题意:

要到n个城市送披萨,每个城市只能经过一次,最后要回到原点,求最短路径。

要点:

经典的TSP问题,从0出发找到一条回路回到0,这就意味着可以回溯到前面的城市重新出发,这样就比较难。基本上可以想到先用Floyd算法求出每两个点的最短路径,然后就是DP,定义一个d[i][s]数组,表示当前在第i个城市,已经经过了s集合中的城市(包括i),s用二进制存储。

这样可以写出状态转移方程:d[i][s] = min(d[i][s], map[j][i] + d[j][s ^ (1 << (i - 1))]),在没经过城市I的状态中,寻找合适的中间点J使得距离更短,和Floyd一样。注意这题是有向图,i到j和j到i不一样。


15591242 Seasonal
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值