adfsdgh

ykj48 流星雨 2024-05-12 19:02:24 8
#include<bits/stdc++.h>
using namespace std;
int a[1100][1100],dp[1100][1100],dp1[1100][1100];
int main(){
//	freopen("A.in","r",stdin);
//	freopen("A.out","w",stdout);
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
			cin>>a[i][j];
		}
	}
	dp[1][1]=a[1][1];
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
			if(i==1)
			{
				dp[i][j]=dp[i][j-1]+a[i][j];
				dp[i][j-1]=0;
			}
			else if(j==1)
			{
				dp[i][j]=dp[i-1][j]+a[i][j];
				dp[i-1][j]=0;
			}
			else
			{
				if(dp[i-1][j]>dp[i][j-1]){
					dp[i][j]=dp[i-1][j]+a[i][j];
					dp[i-1][j]=0;
				}
				else 
				{
					dp[i][j]=dp[i][j-1]+a[i][j];
					dp[i][j-1]=0;
				}
			}
		}
	}

	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
			dp1[i][j]=dp[i][j];
		}
	}

	for(int i=n;i>=1;i--)
	{
		for(int j=m;j>=1;j--)
		{
			if(i==n)
			{
				dp1[i][j]=dp1[i][j+1]+a[i][j];
			}
			else if(j==m)
			{
				dp1[i][j]=dp1[i+1][j]+a[i][j];
			}
			else
			{
				dp1[i][j]=max(dp1[i+1][j],dp1[i][j+1])+a[i][j];
			}
		}
	}
	cout<<dp[n][m]+dp1[1][1];
	return 0;
}
{{ vote && vote.total.up }}