dp专题 第二题 最大子矩阵
2017-04-05 22:27
162 查看
1、简单描述
输入一个n*n的矩阵,输出最大的子矩阵之和
2、简单思路
#include<bits/stdc++.h>
using namespace std;
int fun(int b[101],int n)
{
int i,Max,c;
c=0;
Max=0;
for(i=1;i<=n;i++)
{
if(c>0)
c+=b[i];
else c=b[i];
if(Max<c)
Max=c;
}
return Max;
} //最大子序列和
int main()
{
int i,j,Max,sum,k,n;
int a[101][101],b[101];
cin>>n;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
cin>>a[i][j];
Max=0;
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
b[j]=0;
for(j=i;j<=n;j++)
{
for(k=1;k<=n;k++)
b[k]+=a[j][k];
sum=fun(b,n);
if(Max<sum)
Max=sum;
}
} //压缩成一维数组
cout<<Max<<endl;
return 0;
}
将矩阵的每一列不同行的元素遍历相加,然后成为了一行元素,转化为求最大子段和问题。
输入一个n*n的矩阵,输出最大的子矩阵之和
2、简单思路
#include<bits/stdc++.h>
using namespace std;
int fun(int b[101],int n)
{
int i,Max,c;
c=0;
Max=0;
for(i=1;i<=n;i++)
{
if(c>0)
c+=b[i];
else c=b[i];
if(Max<c)
Max=c;
}
return Max;
} //最大子序列和
int main()
{
int i,j,Max,sum,k,n;
int a[101][101],b[101];
cin>>n;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
cin>>a[i][j];
Max=0;
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
b[j]=0;
for(j=i;j<=n;j++)
{
for(k=1;k<=n;k++)
b[k]+=a[j][k];
sum=fun(b,n);
if(Max<sum)
Max=sum;
}
} //压缩成一维数组
cout<<Max<<endl;
return 0;
}
将矩阵的每一列不同行的元素遍历相加,然后成为了一行元素,转化为求最大子段和问题。
相关文章推荐
- URAL 1146 Maximum Sum(最大子矩阵的和 DP)
- HDU 1559 最大子矩阵 (给定大小) DP
- Dp_关于最大子矩阵的问题总结
- 51nod1051_DP求最大子矩阵
- bzoj 1084: [SCOI2005]最大子矩阵 (DP)
- HDU 1081 最大子矩阵(LCS_DP+前缀和)
- BZOJ 1084: [SCOI2005]最大子矩阵( dp )
- bzoj1084: [SCOI2005]最大子矩阵(dp)
- dp解决最大子矩阵问题
- hdu 1559 最大子矩阵(DP)
- poj 1050 To the Max 最大子矩阵和 经典dp
- #HDU 1506 dp求最大子矩阵
- hdu----(1599)最大子矩阵(几何/dp)
- 【DP】BZOJ1084(SCOI2005)[最大子矩阵]题解
- [POJ 1050] To the Max DP+最大子矩阵和
- 51nod 1051 最大子矩阵和 (dp )
- HDU 1559 最大子矩阵--dp--(最大和子矩阵模型)
- HDU 1505 City Game(DP求二维最大子矩阵)
- hdoj 2830 Matrix Swapping II (DP求最大子矩阵的变型题)
- 最大子矩阵和【dp】