题意:从0走遍1~n最后再返回到0,一个点可以走多次,求经过的最短距离。
分析:由于一个点可以走多次,所以需要求出任意两点间的最短距离,就要用到floyd算法,同时接下来可以搜索做复杂度是O(n!),而状态压缩的时间效率就高了,关于DP自己有时候状态转移方程知道了,却不知道如何去实现,循环时哪层放在外面,哪层放在里面,所以很容易把DP写成了暴力的搜索,自己要多想想。
状态转移方程:dp[S][i] = min(dp[S^(1<<(i-1))][j] + dis[j][i],dp[S][i])
四不像的搜索:
#include <iostream>
#include &