博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
听课笔记--DP--最大子矩阵和
阅读量:5246 次
发布时间:2019-06-14

本文共 1315 字,大约阅读时间需要 4 分钟。


最大子矩阵问题

给定一个n*n(0<n<=120)的矩阵,

矩阵内元素有正有负,

请找到此矩阵的内部元素和最大的子矩阵

样例输入:

4

0 -2 -7  0 

9  2 -6  2 

-4  1 -4  1 

-1  8  0 -2 

样例输出:

15


  • 方法一:

    用二维前缀和维护然后一个个点遍历;

    时间复杂度:O(N4);

  • 方法二:

    DP

    先请明白这道题:

    嗯?这不是一维的吗。和这道题有什么关系?

    请看这张图:

    14551.png

    这样就不难看出,我们只要枚举区间的左端点l和右端点r;   同时用维护的二维前缀和求出每一段1,2,3,4,的值   然后竖着来一遍最大字段和(O(N))就好了   时间复杂度:O(N3)

代码:

#include 
#include
#include
#include
#include
using namespace std;const int maxn=150;int a[maxn][maxn];int sum[maxn][maxn];int line[maxn],c[maxn];int l,r;int n;int solve(){ int minx=min(0,line[1]),maxx=line[1];// for(int i=2;i<=n;i++) { maxx=max(maxx,c[i]-minx); minx=min(minx,c[i]); } return maxx;}int main(){ int ans=-99999; cin>>n; for(int i=1;i<=n;i++) { for(int j=1;j<=n;j++) { cin>>a[i][j]; sum[i][j]=sum[i][j-1]+a[i][j]; } } for(r=1;r<=n;r++) { for(l=1;l<=r;l++) { for(int i=1;i<=n;i++) { line[i]=sum[i][r]-sum[i][l]+a[i][l]; c[i]=c[i-1]+line[i]; } ans=max(solve(),ans); memset(c,0,sizeof(c)); memset(line,0,sizeof(line)); } } cout<
<

转载于:https://www.cnblogs.com/Rye-Catcher/p/8478839.html

你可能感兴趣的文章
Jenkins关闭、重启,Jenkins服务的启动、停止方法。
查看>>
CF E2 - Array and Segments (Hard version) (线段树)
查看>>
Linux SPI总线和设备驱动架构之四:SPI数据传输的队列化
查看>>
SIGPIPE并产生一个信号处理
查看>>
CentOS
查看>>
Linux pipe函数
查看>>
java equals 小记
查看>>
爬虫-通用代码框架
查看>>
2019春 软件工程实践 助教总结
查看>>
YUV 格式的视频呈现
查看>>
Android弹出框的学习
查看>>
现代程序设计 作业1
查看>>
在android开发中添加外挂字体
查看>>
Zerver是一个C#开发的Nginx+PHP+Mysql+memcached+redis绿色集成开发环境
查看>>
多线程实现资源共享的问题学习与总结
查看>>
Learning-Python【26】:反射及内置方法
查看>>
torch教程[1]用numpy实现三层全连接神经网络
查看>>
java实现哈弗曼树
查看>>
转:Web 测试的创作与调试技术
查看>>
python学习笔记3-列表
查看>>