题目链接:http://poj.org/problem?id=1050
//zhaomingming 1050 Accepted 580K 63MS C++ 1356B
/**思路:用 i,j表示起始行和终止行,遍历所有可能
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
当 i = 2; j = 4时,即在2,3,4行求解。
我们考察其中一种情况 i=2 j=4,这样就相当与选中了2 3 4三行,求那几列的组合能获得最大值,由于总是 2 3 4行,所以我们可以将这3行”捆绑”起来,变为求 4(9-4-1),11(8+2+1),-10(-6-4+0),7(7+2-2)
的最大子段和,问题成功转化为一维的情况!
**/
#include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
using namespace std;
const int M = 1010;
int a[M][M];
int n;
int ans[M];
int maxx;
int solve()
{
memset(dp,0,sizeof(dp));
maxx = -999;
for(int i = 1; i <= n; i++)
{
for(int j = 1; j <= n; j++)
{
if(i == j) //单独处理,只有一行的情况
{
for(int k = 1; k <= n; k++)
ans[k] = a[i][k];
}
else
{
for(int k = 1; k <= n; k++)
{
ans[k] = 0;
for(int h = i; h <= j; h++) //捆绑
{
ans[k] += a[h][k];
}
}
}
//这里就是一维的,求最大连续子段和
int sum = 0,max1 = 0;
for(int k = 1; k <= n; k++)
{
sum += ans[k];
if(sum > max1)
max1 = sum;
else if(sum < 0)
sum = 0;
}
if(maxx < max1)
maxx = max1;
}
}
return 0;
}
int main()
{
cin >> n;
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
cin >> a[i][j];
solve();
cout << maxx<<endl;
return 0;
}
本文介绍了一种解决二维矩阵中寻找最大子矩阵和的方法,通过将问题转化为一维最大子数组和问题来简化求解过程。具体实现上,采用双重循环遍历所有可能的行区间,并将选定行区间内的列元素进行累加,最终找到最大和。
463

被折叠的 条评论
为什么被折叠?



