1074.txt
来自「ZOJ 动态规划算法题目入门与提高 源代码」· 文本 代码 · 共 52 行
TXT
52 行
#include <iostream>
using namespace std;
int a[101][101];
int maxsum(int a[],int n)//一维最大串
{
int sum=-10000000,b=0;
int i;
for(i=0;i<n;i++)
{
if (b>0)
b+=a[i];
else
b=a[i];
if(b>sum)
sum=b;
}
return sum;
}
int maxsum2(int m,int n)//二维最大串
{
int sum = -10000000;
int i,j,k,max;
int* b = new int[n+1];
for (i=0;i<m;i++)
{
for(k=0;k<n;k++)
b[k]=a[i][k];
max = maxsum(b,n);//第i列的一维最大串
if(max>sum)
sum=max;
for(j=i+1;j<m;j++)
{
for (k=0;k<=n;k++)b[k]+=a[j][k];
max = maxsum(b,n);//类似maxsum,通过每列相加求二维最大串
if(max>sum)sum=max;
}
}
delete []b;
return sum;
}
int main()
{
int n,i,j;
cin >> n;
for (i=0;i<n;i++)
for (j=0;j<n;j++)
cin >> a[i][j];
cout << maxsum2(n,n) << endl;
return 0;
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?