为甚么55分啊~~~
查看原帖
为甚么55分啊~~~
236980
王炸拆开打楼主2020/11/12 18:49

自认为和抄题解没区别了已经

#include<iostream>
#include<cstdio>
#include<cstring>
#define Re register
#define LL long long 
using namespace std;
LL f[1111][1111][4],a[1111][1111];//[0]=from under  [1]=from left  [2]=from above  [3]=real
inline LL read(){
	register LL x=0,f=1;char ch=getchar();
	while(!isdigit(ch)){if(ch=='-') f=-1;ch=getchar();}
	while(isdigit(ch)){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
	return x*f;
}
int main(){
	int n=read(),m=read();
	LL ma=-0x3f3f3f3f3f3f3f3f;
	for(int i=1;i<=n;++i)
		for(int j=1;j<=m;++j)
			a[i][j]=read();
	f[1][1][2] = ma; f[1][1][0] = ma; f[1][1][1] = ma; f[1][1][3] = a[1][1];
	for(int i=2;i<=n;++i){f[i][1][0]=f[i][i][1]=ma;f[i][1][3]=f[i][1][2]=f[i-1][1][3]+a[i][1];}
	for (int i=2;i<=m;++i){f[1][i][0]=f[1][i][2]=ma;}
	for(int i=2;i<=m;++i){
		for(int j=1;j<=n;++j) f[j][i][1]=f[j][i-1][3]+a[j][i];
		for(int j=n-1;j>=1;--j) f[j][i][0]=max(f[j+1][i][1],f[j+1][i][0])+a[j][i];
		for(int j=2;j<=n;++j) f[j][i][2]=max(f[j-1][i][1],f[j-1][i][2])+a[j][i];
		for(int j=1;j<=n;++j) f[j][i][3]=max(max(f[j][i][1],f[j][i][0]),f[j][i][2]);
	}
	printf("%lld",f[n][m][3]);
	return 0;
}
2020/11/12 18:49
加载中...