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分是那个细节没处理好, 感谢
全部评论
如果不写注释等方便大家看的内容,只贴代码很容易沉的
1 回复 分享
发布于 2020-08-31 16:07
。。。我一发就过了
点赞 回复 分享
发布于 2020-09-01 21:52
https://paste.ubuntu.com/p/7w2XR82fZR/ 这是我的代码...我帮你看看吧
点赞 回复 分享
发布于 2020-09-01 21:54
哦,我知道你问题在哪了,你这样写的话是第一个必定在第一个位子放置了花,其实并不是第一个位子要放第一朵花,初始化的问题
点赞 回复 分享
发布于 2020-09-01 22:10

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务