竞赛讨论区 > 95分求助
头像
Myzc
发布于 2020-08-30 15:26
+ 关注

95分求助

# 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) 回帖
加载中...
话题 回帖

本文相关内容

等你来战

查看全部

热门推荐