最短Hamilton路径
原题链接
听我说,家人们,有个问题,对于这道题来说,首先是利用状态压缩来做对吧。
- y总的打卡, 以及其他人的打卡,都是i从0开始枚举所有的状态。
- 那其实初始化的时候不是已经将f[1][0] = 1 也就是 f[00...001][0] = 0
了。
- 所以在遍历的时候是不是能从f[2][0] 也就是f[00...10][0]
的时候开始.
-
下面得代码能过,只是i从0改为了i从2开始
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
const int N = 20, M = 1 << N;
int n;
int f[M][N];
int w[N][N];
int main()
{
scanf("%d", &n);
for (int i = 0; i < n; i++)
for (int j = 0; j < n; j++)
scanf("%d", &w[i][j]);
memset(f, 0x3f, sizeof f);
f[1][0] = 0;
for (int i = 2; i < 1 << n; i++)
for (int j = 0; j < n; j++)
if (i >> j & 1)
{
for (int k = 0; k < n; k++)
if (i - (1 << j) >> k & 1)
f[i][j] = min(f[i][j], f[i - (1 << j)][k] + w[k][j]);
}
printf("%d\n", f[(1 << n) - 1][n - 1]);
return 0;
}