动态规划货郎担问题c++
时间: 2023-11-23 14:54:01 浏览: 140
动态规划货郎担问题是指在给定的n个城市之间,求解一条经过每个城市恰好一次的最短路径。这个问题可以使用动态规划算法来解决。具体来说,可以使用一个二维数组g[i][S]来表示从城市i开始,经过集合S中的所有城市,最终回到城市1的最短路径长度。其中,集合S是除了城市1之外的所有城市的集合。根据动态规划的思想,可以先求解子问题,再从子问题的解得到原问题的解。因此,可以按照以下步骤来求解动态规划货郎担问题:
. 初始化g[i][S],当S中只有一个城市j时,g[i][{j}]的值为城市i到城市j的距离。
2. 对于集合S中的每个城市j,计算g[i][S]的值。具体来说,可以枚举S中除了j之外的所有城市k,计算g[k][S-{j}]的值,然后加上城市i到城市j的距离,取最小值即可。
3. 最终的答案是g[{2,3,...,n}],即从城市1开始,经过除了城市1之外的所有城市,最终回到城市1的最短路径长度。
下面是动态规划货郎担问题的C++代码实现:
```
#include <iostream>
#include <cstring>
using namespace std;
const int MAXN = 20;
const int INF = 0x3f3f3f3f;
int n, cost[MAXN][MAXN], g[MAXN][1 << MAXN];
int tsp(int start, int state) {
if (state == (1 << n) - 1) {
return cost[start][0];
}
if (g[start][state] != -1) {
return g[start][state];
}
int ans = INF;
for (int i = 0; i < n; i++) {
if ((state & (1 << i)) == 0) {
ans = min(ans, cost[start][i] + tsp(i, state | (1 << i)));
}
}
return g[start][state] = ans;
}
int main() {
memset(g, -1, sizeof(g));
cout << "请输入n的值" << endl;
cin >> n;
int cc[MAXN][MAXN];
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
cout << "请输入各成本值" << endl;
cin >> cc[i][j];
cost[i][j] = cc[i][j];
}
}
cout << tsp(0, 1) << endl;
return 0;
}
```
阅读全文