# include<bits/stdc++.h>
using namespace std;
int num[105][105];
int pre[105][105];
int dp[105][105];
void print(int x, int y){
if(pre[y][x] == x){
printf("%d ", x);
return;
}
print(pre[y][x], y-1);
printf("%d ", x);
}
int main(){
int x, y;
scanf("%d %d", &y, &x);
for(int i=1; i<=y; i++){
for(int j=1; j<=x; j++){
scanf("%d", &num[i][j]);
}
}
for(int i=1; i<=x - y + 1; i++){
dp[1][i] = num[1][i];
pre[1][i] = i;
}
for(int i=2; i<=y; i++){
for(int j=i; j<=x - y + i; j++){
for(int k=i-1; k < j; k++){
if(dp[i-1][k] + num[i][j] > dp[i][j]){
dp[i][j] = max(dp[i][j], dp[i-1][k] + num[i][j]);
pre[i][j] = k;
}
}
}
}
int maxn = 0;
int t;
for(int i=1; i<=x; i++){
if(maxn < dp[y][i]){
maxn = max(maxn, dp[y][i]);
t = i;
}
}
printf("%d\n", maxn);
print(t, y);
return 0;
}
请问各位大神, 我这份95分是那个细节没处理好, 感谢
全部评论
(4) 回帖