【算法练习】搜索/剪枝 百炼 poj4124:海贼王之伟大航路

参考blog:http://blog.sina.com.cn/s/blog_a8efbf5d0102vo9u.html

题目链接:http://bailian.openjudge.cn/practice/4124

这个题经过我的百度搜索,并不是思考,因为思考没有想出来好的方法,于是我就准备站在巨人的肩膀上看看,然后看了几个blog,发现可以用状压dp  参考这个https://www.cnblogs.com/Tony-Double-Sky/p/9283254.html

现在在刷搜索的题,就先用dfs+剪枝来做做,这个思路确实不是我想到的,这类题型可以概括成旅行商问题(?)

note:是旅行商问题的相似问题,但是这个问题不需要形成环路,所以更简单一点。

感觉可以用这个方法解决,记录一下。

需要这样一种剪枝想法:记录下来之前经过的所有岛 到某个岛后 去对比一下 如果经过了同样的岛此时的距离却比原来距离大 那就不用再做下去了 

举个简单的例子  0->3->1->2 和 0->1->3->2这两种走法耗时是不同的 如果前者时间小 我们现在做到后者的情况 不论后面怎么走 肯定都比前者的最小时间哒 所以就不用再做下去

4124:海贼王之伟大航路

总时间限制: 

1000ms

 

内存限制: 

65536kB

描述

“我是要成为海贼王的男人

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值