30分求调
查看原帖
30分求调
1776938
Lucian2007楼主2025/7/27 23:22

看了半天真的不知道哪里有问题了()

#include<bits/stdc++.h>
using namespace std;
const int N=1010;
const long long MAX=1e18;
int c,T,n,m;
long long s;
long long k;
long long a[N][N];
long long f[N][N];
int main()
{
	scanf("%d%d",&c,&T);
	while(T--)
	{
		scanf("%d%d%lld%lld",&n,&m,&s,&k);
		for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++)
		scanf("%lld",&a[i][j]);
		for(int i=1;i<=n;i++)
		for(int j=0;j<=m+1;j++)
		{
			f[i][j]=-MAX;
		}
		for(int j=1;j<=m;j++)
		{
			long long v=s+a[1][j];
			if(v<=0) continue;
			v=min(v,k);
			f[1][j]=v;
		}
		for(int i=1;i<=n;i++)
		{
			for(int h=0;h<5;h++)
			{
				for(int j=1;j<=m;j++)
				{
				if(f[i][j-1]!=-MAX)
				{
					long long v=f[i][j-1]+a[i][j];
					if(v<=0) continue;
					v=min(v,k);
					if(v>f[i][j]) f[i][j]=v;
				}
				}
				for(int j=m;j>=1;j--)
				{
					if(f[i][j+1]!=-MAX)
					{
						long long v=f[i][j+1]+a[i][j];
						if(v<=0) continue;
						v=min(v,k);
						if(v>f[i][j])  f[i][j]=v;
					}
				}	
			}
				if(i<n)
				{
					for(int j=1;j<=m;j++)
					{
						if(f[i][j]==-MAX) continue;
						long long v=f[i][j]+a[i+1][j];
						if(v<=0) continue;
						v=min(v,k);
						if(v>f[i+1][j]) f[i+1][j]=v;
					}
				}
		}
		long long ans=-1;
		for(int j=1;j<=m;j++)
		{
			if(f[n][j]!=-MAX) ans=max(ans,f[n][j]);
		}
		printf("%lld\n",ans);	
	}
	return 0;
}
2025/7/27 23:22
加载中...