题目链接:P1216 [USACO1.5] [IOI1994]数字三角形 Number Triangles - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
解题思路:
最优路径问题,首先想到dfs深度优先搜索,一直往下走再回溯上一格换个方向走
下面是c++代码:
#include<iostream>
#include<algorithm>
using namespace std;
int arr[1010][1010];
int n;
int dfs(int x, int y) {
if (x > n || y > n)return 0;
else return max(dfs(x + 1, y), dfs(x + 1, y + 1)) + arr[x][y];
}
int main()
{
cin >> n;
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= i; j++) {
cin >> arr[i][j];
}
}
cout << dfs(1, 1);
return 0;
}
但是这样超时了,可以优化一下,想到记忆化搜索,就是把经过的最大路径存起来,遇到直接使用即可
c++代码:
#include<iostream>
#include<algorithm>
using namespace std;
int arr[1010][1010];
int value[10001][10001];
int n;
int dfs(int x, int y) {
if (value[x][y])return value[x][y];
int sum = 0;
if (x > n || y > n)return 0;
else sum = max(dfs(x + 1, y), dfs(x + 1, y + 1)) + arr[x][y];
value[x][y] = sum;
return sum;
}
int main()
{
cin >> n;
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= i; j++) {
cin >> arr[i][j];
}
}
cout << dfs(1,1);
return 0;
}
好多了,但是还是有一个测试点t了,直接转换成动态规划
c++代码:
#include<iostream>
#include<algorithm>
using namespace std;
int arr[1010][1010];
int value[10001][10001];
int n;
int dfs(int x, int y) {
if (value[x][y])return value[x][y];
int sum = 0;
if (x > n || y > n)return 0;
else sum = max(dfs(x + 1, y), dfs(x + 1, y + 1)) + arr[x][y];
value[x][y] = sum;
return sum;
}
int main()
{
cin >> n;
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= i; j++) {
cin >> arr[i][j];
}
}
for (int i = n; i >= 1; i--) {
for (int j = 1; j <= n; j++) {
value[i][j] = max(value[i + 1][j], value[i + 1][j + 1]) + arr[i][j];
}
}
cout << value[1][1];
return 0;
}
ac了,遇到类似的题都可以先dfs再剪枝再转换成动态规划,可以直接套用模板