最大子矩阵和问题

问题:

求一个M*N的矩阵的最大子矩阵和。
比如在如下这个矩阵中:
0 -2 -7 0
9 2 -6 2
-4 1 -4 1
-1 8 0 -2   ………………【1】
拥有最大和的子矩阵为:
9 2
-4 1
-1 8
其和为15。


分析:


我们首先想到的方法就是穷举一个矩阵的所有子矩阵,然而一个n*n的矩阵的子矩阵的个数当n比较大时时一个很大的数字 O(n^2*n^2),显然此方法不可行。
  怎么使得问题的复杂度降低呢?对了,相信大家应该知道了,用动态规划。


思路:假设当前考虑从第r行到第k行的矩阵,可以先求从第r行到第k行每一列的元素和,放在一维数组中。那么现在就转换成求一维数组的最大字段和问题了!


循环DP,共三层循环。
最外层i循环1-N,表明子矩阵是从第i列开始累加的。
第二层j循环i-N,表明子矩阵是从第i列累加到第j列。
第三层k从1到M做一维DP。

//Attention: a does not stand for two_dimensional array's first address!
//It actually stand for two_level point!! 
int MaxSum(int row,int col,int **a)
{
	int i,j,k,sum=0,max;
	int *b=(int *)malloc(sizeof(int)*col+1);  

	for (i=1;i<=row;i++)
	{
		for (k=1;k<=col;k++)
		{
			b[k]=0;
		}
		for (j=i;j<=row;j++)
		{
			for (k=1;k<=col;k++)
			{
				b[k]+=a[j][k];
			}
			max=MaxSequence(col,b);
			if (max>sum)
			{
				sum=max;
			}
		}
	}
	return sum;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值