最大子矩阵(普通和01)

文章目录

    • 普通矩阵(单个矩阵值为任何数)
      • 最大子段和
      • 扩展到二维情况
    • 01矩阵(单个矩阵值为0或1)
    • 代码:

普通矩阵(单个矩阵值为任何数)

例题:POJ 1074
在这里插入图片描述
求出其中最大的子矩阵
答案是:
9 2
-4 1
-1 8
最大和是15
我们先想想如果不是矩阵,是一个数组,求其中连续的最长一段,咋做?

最大子段和

我们用b[i]来表示a[0]…a[1]的最大子段和
那么b [ i ] =max ( b [i - 1 ] + a [ i ], a [ i ] )
当a[n] 大于dp[n-1](前n-1个元素序列的最大子段和)。此时舍弃前面的子段和,即断开。
否则的话,把a[n]连接到前n-1个元素序列的最大和子段上,即dp[n] = dp[n-1] + a[n]

int MaxSum(int n,int *a)
{int sum=0,b=0;for(int i=0;i<n;i++){if(b>0) sum=max(sum,b+=a[i]);//不要忘了把b更新else sum=max(b=a[i],sum);}return sum;
}

扩展到二维情况

二维矩阵排列方式如图
参考题解
在这里插入图片描述
如果红色是我们要找的最大子矩阵
那和就是:(a[q][i]+…+a[p][i],a[q][i+1]+…+a[p][i+1],…,a[q][j]+…a[p][j])=(sum1,sum2,…,sumn
sum也就是每一列的相同行数相加
这不也是sun的一维数组,那其实就是一个一维数组的最大子段问题
如果把二维数组看成是纵向的一维数组和横向的一维数组

#include <iostream>
#include <cstring>
using namespace std;int maxsub(int a[], int n)
{int i, max = a[0], b = 0;for (i = 0; i < n; i++){if (b + a[i] >= a[i])	//当n-1的最大字段和+a[i]>=原来的最大字段和b += a[i];	//则n的最大字段和为b+a[i]else	//否则,就是a[i]b = a[i];if (b > max)	//找到最大的最大字段和max = b;}return max;
}int main()
{int n, i, j, k, maxsubrec, maxsubarr, m;int dp[101][101], arr[101];cin >> n >> m;for (i = 0; i < n; i++)for (j = 0; j < m; j++)cin >> dp[i][j];maxsubrec = dp[0][0];for (i = 0; i < n; i++)	//i用于标识从哪行开始,依次选择行{memset(arr, 0, sizeof(arr));for (j = i; j < n; j++)	//从第i行开始,j为选择几行{for (k = 0; k < m; k++)	//从1列选择到m列,压缩行arr[k] += dp[j][k];//arr表示每列的值maxsubarr = maxsub(arr, m);	//从每一个压缩行中选择最大字段和if (maxsubarr > maxsubrec) maxsubrec = maxsubarr;}}cout << maxsubrec << endl;return 0;
}

01矩阵(单个矩阵值为0或1)

参考题解
POJ - 3494
在这里插入图片描述
其实就是没有负数情况
我一开始想的是将最大子矩阵的代码中,如果一个数为0就赋值为-10000(这样程序就肯定不会选择这个块)
但是这样会超时
针对01矩阵我们可以这么想:
每一个单元格的值等于它所在列的连续1的数量,如果当前行为1,则当前行的值就等于上一行加1,如果当前行为0,则他的值也是0
我们扫描每一行,求出这一行中可形成的矩形最大面积,然后去最大情况即可
然后我们要用到一个单调递减的单调栈,
如果栈为空或者当前元素大于等于栈顶元素,则入栈
若栈非空且当前元素小于栈顶元素,则将栈顶弹出,更新面积最大值,直到栈空或者遇到第一个大于等于当前元素
将最后一个出栈的栈顶元素(最后一个大于当前元素的)向左右延伸,修改其值,并入栈。
核心都是对于每个高度为h的矩形,找到最左高度大于等于它的位置,和最右的位置。
在这里插入图片描述
我们看第三行:
0 1 3 2 0 0 0
0先入栈,然后1入栈,然后3入栈,然后到2时,2<3,计算此时的矩阵面积=(4-3) * 3=3,此时最大面积是3,然后将值3改为2,此时就是0 1 2 2 ,然后0<2,计算此时面积 = (5-3) * 2=4,最大面积就是4,一次类推,都是按照这个操作

代码:

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<stack>
using namespace std;int main()
{//top指向栈顶;tmp为临时变量,记录面积的值;ans为答案,记录面积的最大值 int i,j,m,n,x,top,tmp,ans,h[2020],a[2020];stack<int> st; //单调栈,记录位置 while(~scanf("%d%d",&m,&n)){ans=0;memset(h,0,sizeof(h)); //用于第一行的处理for(i=0;i<m;i++){ //扫描每一行 for(j=1;j<=n;j++){scanf("%d",&x);if(x==1) h[j]=h[j]+1; //如果是1,则在上一行本列的基础上+1 else h[j]=0; //否则为0 a[j]=h[j]; //a数组用来向左右扩展}a[n+1]=-1; //设最后元素为最小值,以最后让栈内元素出栈 for(j=1;j<=n+1;j++){if(st.empty()||a[j]>=a[st.top()]){ //如果栈为空或入栈元素大于等于栈顶元素,则入栈 st.push(j);}else{while(!st.empty()&&a[j]<a[st.top()]){ //如果栈非空并且入栈元素小于栈顶元素,则将栈顶元素出栈 top=st.top();st.pop();tmp=(j-top)*a[top]; //计算面积值 if(tmp>ans) ans=tmp; //更新面积最大值 }st.push(top); //将最后一次出栈的栈顶元素延伸并入栈 a[top]=a[j]; //修改其对应的值 }}}printf("%d\n",ans);}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319907.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自动化流程开源框架BotSharp

BotSharp是一款为方便构建智能对话机器人平台而开发的开源框架&#xff0c;最大的特点是所有模型算法都是基于.NET Core开发实现&#xff0c;甚至最基本的Penn Treebank分词标准&#xff0c;都重新用C#实现了。在机器学习python占绝对优势的时代算是不可多得的项目。该项目涉及…

积极参与开源项目,促进.NET Core生态社区发展

今天早上在微信群里聊天聊到百度的SDK 已经支持.NET Core, 百度已经在3月份就支持了&#xff0c;想起当时还是我在他们的github上提的issue&#xff1a; https://github.com/Baidu-AIP/dotnet-sdk/issues/3。.NET Core生态社区的发展已经四年多时间&#xff0c;日趋完善&#x…

Service Fabric 与Ocelot 的集成

概要云应用程序通常都需要使用前端网关&#xff0c;为用户、设备或其他应用程序提供同一个入口点。 在 Service Fabric 中&#xff0c;网关可以是任意无状态服务&#xff08;如 ASP.NET Core 应用程序&#xff09; 。本文介绍了如何将Ocelot用作 Service Fabric 应用程序的网关…

图论复习——最短路

知识点 最短路径算法 最短路径树 每个点uuu的父亲为使uuu得到最短距离的前驱节点&#xff0c;若有多个&#xff0c;则取任意一个。 题目 CF449B Jzzhu and Cities Blog CF464E The Classic Problem Blog [XSY3888] 传送门 对每个点uuu&#xff0c;记d(u)d(u)d(u)表示uuu…

T-Dongle-S3开发笔记——创建工程

创建Hello world工程 打开命令面板 方法1&#xff1a;查看->命令面板 方法2&#xff1a;按F1 选择ESP-IDF:展示示例项目 创建helloworld 选择串口 选择芯片 至此可以编译下载运行了 运行后打印的信息显示flash只有2M。但是板子上电flash是W25Q32 4MB的吗 16M-bit

hdu 1576 A/B

文章目录题目&#xff1a;题解&#xff1a;代码&#xff1a;hdu 1576题目&#xff1a; 要求(A/B)%9973&#xff0c;但由于A很大&#xff0c;我们只给出n(nA%9973)(我们给定的A必能被B整除&#xff0c;且gcd(B,9973) 1)。 Input 数据的第一行是一个T&#xff0c;表示有T组数据。…

ASP.NET Core 中断请求了解一下(翻译)

本文所讲方式仅适用于托管在Kestrel Server中的应用。如果托管在IIS和IIS Express上时&#xff0c;ASP.NET Core Module(ANCM)并不会告诉ASP.NET Core在客户端断开连接时中止请求。但可喜的是&#xff0c;ANCM预计在.NET Core 2.2中会完善这一机制。1. 引言假设有一个耗时的Act…

.net core实践系列之短信服务-架构优化

前言通过前面的几篇文章&#xff0c;讲解了一个短信服务的架构设计与实现。然而初始方案并非100%完美的&#xff0c;我们仍可以对该架构做一些优化与调整。同时我也希望通过这篇文章与大家分享一下&#xff0c;我的架构设计理念。源码地址&#xff1a;https://github.com/SkyCh…

游戏 (博弈论)

https://blog.csdn.net/Mys_C_K/article/details/91443390

.NET Core中Object Pool的简单使用

前言复用&#xff0c;是一个重要的话题&#xff0c;也是我们日常开发中经常遇到的&#xff0c;不可避免的问题。举个最为简单&#xff0c;大家最为熟悉的例子&#xff0c;数据库连接池&#xff0c;就是复用数据库连接。那么复用的意义在那里呢&#xff1f;简单来说就是减少不必…

.Net Core应用框架Util介绍(三)

上篇.Net Core应用框架Util介绍&#xff08;二&#xff09;介绍了Util的开发环境&#xff0c;并让你把Demo运行起来。本文将介绍该Demo的前端Angular运行机制以及目录结构。目录结构在VS上打开Util Demo&#xff0c;会看见如下的目录结构。现代前端通常采用VS Code开发&#xf…

Ocelot简易教程(三)之主要特性及路由详解

作者&#xff1a;依乐祝原文地址&#xff1a;https://www.cnblogs.com/yilezhu/p/9664977.html上篇《Ocelot简易教程&#xff08;二&#xff09;之快速开始2》教大家如何快速跑起来一个ocelot实例项目&#xff0c;也只是简单的对Ocelot进行了配置&#xff0c;这篇文章会给大家详…

Poj 3070 Fibonacci

Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 26063 Accepted: 17394文章目录Description题意&#xff1a;题解&#xff1a;代码&#xff1a;Poj 3070 FibonacciDescription In the Fibonacci integer sequence, F0 0, F1 1, and Fn Fn − 1 Fn − 2 for…

生成函数化简技巧

一些重要式子 ∑i0∞xi11−x\sum_{i0}^{\infty}x^i\frac{1}{1-x}∑i0∞​xi1−x1​ 推论&#xff1a; 11−ax∑i0∞aixi\frac{1}{1-ax}\sum_{i0}^{\infty}a^ix^i1−ax1​∑i0∞​aixi 11−xk∑i0∞xik\frac{1}{1-x^k}\sum_{i0}^{\infty}x^{ik}1−xk1​∑i0∞​xik 11−cxk∑i0∞…

.NET西安社区 [拥抱开源,又见 .NET] 活动简报

拥抱开源, 又见 .NET」随着 .NET Core的发布和开源&#xff0c;.NET又重新回到了人们的视野。除了开源、跨平台、高性能以及优秀的语言特性&#xff0c;越来越多的第三方开源库也出现在了Github上——包括ML.NET机器学习、Xamarin移动开发平台、基于Actor模型的分布式框架Orlea…

dotnet core高吞吐Http api服务组件FastHttpApi

简介是dotNet core下基于Beetlex实现的一个高度精简化和高吞吐的HTTP API服务开源组件&#xff0c;它并没有完全实现HTTP SERVER的所有功能&#xff0c;而是只实现了在APP和WEB中提供数据服务最常用两个指令GET/SET&#xff0c;满足在应用实现JSON,PROTOBUF和MSGPACK等基于HTTP…

ASP.NET Core 中的中间件

前言由于是第一次写博客,如果您看到此文章,希望大家抱着找错误、批判的心态来看。 sky!何为中间件?在 ASP.NET Framework 中应该都知道请求管道。可参考&#xff1a;浅谈 ASP.NET 的内部机制 系列&#xff0c;个人感觉超详细。题外话&#xff1a;说到请求管道&#xff0c;就想…

.NET Core中的性能测试工具BenchmarkDotnet

背景介绍之前一篇博客中&#xff0c;我们讲解.NET Core中的CSV解析库&#xff0c;在文章的最后&#xff0c;作者使用了性能基准测试工具BenchmarkDotNet测试了2个不同CSV解析库的性能&#xff0c;本篇我们来详细介绍一下BenchmarkDotNet。原文链接&#xff1a;https://dotnetco…

some useful tricks

异或题思考方向&#xff1a;01trie树&#xff0c;分治 2. 二分图最大匹配&#xff0c;最大独立集互相转换 3. Snow 4. Code 5. Code 6. Code 7. 题目 #include<iostream> #include<cstdio> using namespace std; const int N100010; int n,p,nxt[N],no[200]…

25大技术主题向您发出最后一次约【惠】邀请

一年一度的微软技术盛会即将在上海世博中心拉开大幕金秋十月&#xff0c;来自两岸三地的百名明星讲师将携 25 大技术主题&#xff0c;齐聚上海为您奉献一场无与伦比的技术视听盛宴您&#xff0c;准备好了吗&#xff1f;25大技术主题公开&#xff0c;不负期待姗姗来迟的5系25大技…