参考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
描述
“我是要成为海贼王的男人