|NOIOJ|动态规划|1768:最大子矩阵
2016-08-29 11:07
225 查看
http://noi.openjudge.cn/ch0206/1768/
枚举矩阵起始行和结束行O(n^2), 然后再枚举一维O(n)求最大字段和即可
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ms(i,j) memset(i, j, sizeof(i));
using namespace std;
int a[105][105];
int n;
int main()
{
scanf("%d", &n);
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
{
scanf("%d", &a[i][j]);
}
int ans = -100000000;
for (int i=1;i<=n;i++)//枚举矩阵起始行
{
int b[105];
ms(b,0);
for (int j=i;j<=n;j++)//枚举矩阵结束行
{
for (int k=1;k<=n;k++) b[k] += a[j][k];//累加和
int f = -100000000;
int ret = -100000000;
for (int k=1;k<=n;k++) //动态规划求最大字段和
{f = max(f+b[k], b[k]); ret = max(ret, f);}
ans = max(ans, ret);
}
}
printf("%d\n", ans);
return 0;
}
枚举矩阵起始行和结束行O(n^2), 然后再枚举一维O(n)求最大字段和即可
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ms(i,j) memset(i, j, sizeof(i));
using namespace std;
int a[105][105];
int n;
int main()
{
scanf("%d", &n);
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
{
scanf("%d", &a[i][j]);
}
int ans = -100000000;
for (int i=1;i<=n;i++)//枚举矩阵起始行
{
int b[105];
ms(b,0);
for (int j=i;j<=n;j++)//枚举矩阵结束行
{
for (int k=1;k<=n;k++) b[k] += a[j][k];//累加和
int f = -100000000;
int ret = -100000000;
for (int k=1;k<=n;k++) //动态规划求最大字段和
{f = max(f+b[k], b[k]); ret = max(ret, f);}
ans = max(ans, ret);
}
}
printf("%d\n", ans);
return 0;
}
相关文章推荐
- 动态规划_题目1139:最大子矩阵
- 1768:最大子矩阵
- 最大子矩阵(动态规划)
- 【51nod1051】【最大子矩阵和】【动态规划】
- 动态规划练习——最大子矩阵
- poj 1050动态规划+最大子矩阵和+二维化为一维来求最大子串和值
- 动态规划 02 (最大子矩阵)
- 最大子矩阵(动态规划)
- 动态规划-最大子矩阵和
- 动态规划最大子矩阵
- 集训第五周动态规划 F题 最大子矩阵和
- 动态规划解决最大子矩阵问题
- 动态规划练习02:最大子矩阵
- 1768:最大子矩阵(NOIP2014初赛最后一题)
- HDU 2870(动态规划-最大子矩阵)
- 1084: [SCOI2005]最大子矩阵 (动态规划)
- 【OJ1768】最大子矩阵
- POJ 1768 最大子矩阵
- BZOJ_1084_[SCOI2005]_最大子矩阵_(动态规划)
- 【动态规划】求二维矩阵的最大和子矩阵