Acwing 91. 最短Hamilton路径

Acwing 91. 最短Hamilton路径_第1张图片状态表示: f[i][j]表示所有从0走到j,走过的所有点是i的所有路径 中的最小值

状态计算:以倒数第二个点来划分集合

Acwing 91. 最短Hamilton路径_第2张图片

 

#include 
#include 
#include 

using namespace std;

const int N = 20, M = 1 << 20;

int w[N][N];
int f[M][N];
int n;

int main()
{
    cin >> n;
    for (int i = 0; i < n; ++ i)
        for (int j = 0; j < n; ++ j)
            cin >> w[i][j];
            
    memset(f, 0x3f, sizeof(f));
    f[1][0] = 0;
    
    for (int i = 1; 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)
                        f[i][j] = min(f[i][j], f[i - (1 << j)][k] + w[k][j]);
                        
    cout << f[(1 << n) - 1][n - 1] << endl;
    
    return 0;
}

你可能感兴趣的:(动态规划,c++,蓝桥杯,算法)