hiho #1502:最大子矩阵(元素和不超过k)
#1502 : 最大子矩阵
描述
给定一个NxM的矩阵A和一个整数K,小Hi希望你能求出其中最大(元素数目最多)的子矩阵,并且该子矩阵中所有元素的和不超过K。
输入
第一行包含三个整数N、M和K。
以下N行每行包含M个整数,表示A。
对于40%的数据,1 <= N, M <= 10
对于100%的数据,1 <= N, M <= 250 1 <= K <= 2147483647 1 <= Aij <= 10000
输出
满足条件最大的子矩阵所包含的元素数目。如果没有子矩阵满足条件,输出-1。
- 样例输入
 - 
3 3 9
1 2 3
2 3 4
3 4 5 - 样例输出
 - 
4
 
思路:
满足条件最大的子矩阵所包含的元素数目。如果没有子矩阵满足条件,输出-1。
与求最大子矩阵题目(hdu1559子矩阵的元素之和最大)方法类似。
设row[x][y]:第x行中前y个数的和
则row[x][q]-row[x][p]:第x行中第p+1~第q个数的和
行x~y列u~v的矩形的元素之和:row[x][v]-row[x][u-1]+row[x+1][v]-row[x+1][u-1]+…+row[y][v]-row[y][u-1]

按照列固定:u~v (第u个数到第v个数), 进行行的探索。
假设从行第p个数开始向下边2递增(每次p加1),假设到第q个数数值和第一次超过设定值,计算矩形面积(q-p)*(v-u+1),
然后从第p个数开始向下边1递增(每次p+1),直到数值和第一次小于设定值。
然后继续操作,直到v=n+1,结束。
代码:
#include <iostream>
#include <algorithm>
using namespace std; int dp[][], a[][];
int ans=-;
int n,m,K;
typedef long long LL; int main()
{ cin >> n>>m>>K;
for (int i = ; i <= n; i++)
{
dp[i][]=;
for (int j = ; j <= m; j++)
{
cin >> a[i][j];
dp[i][j]=dp[i][j-]+a[i][j];
}
} for(int i=;i<=n;++i){
for(int j=i;j<=n;++j){
LL aa=;
for(int k=,l=;k<=n;++k){
aa+=dp[k][j]-dp[k][i-];
while(aa>K){
aa-=dp[l][j]-dp[l][i-];
++l;
}
ans=max(ans,(j-i+)*(k-l+));
}
}
} cout << ans;
}
hiho #1502:最大子矩阵(元素和不超过k)的更多相关文章
- BZOJ 4582 [Usaco2016 Open]Diamond Collector:贪心【相差不超过k】
		
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=4582 题意: 给你n个数. 让你将其中的一些数放入两个不同的集合中,并保证同一集合内两两元 ...
 - HihoCoder 1502 : 最大子矩阵 (双指针)
		
描述 给定一个NxM的矩阵A和一个整数K,小Hi希望你能求出其中最大(元素数目最多)的子矩阵,并且该子矩阵中所有元素的和不超过K. 输入 第一行包含三个整数N.M和K. 以下N行每行包含M个整数,表示 ...
 - ACM 中 矩阵数据的预处理 && 求子矩阵元素和问题
		
我们考虑一个$N\times M$的矩阵数据,若要对矩阵中的部分数据进行读取,比如求某个$a\times b$的子矩阵的元素和,通常我们可以想到$O(ab)$的遍历那个子矩阵,对它的各 ...
 - 求最长的任意两元素差不超过M的子段——双指针+单调队列hdu4123
		
换根dp的部分比较容易,难点在于求求最长的任意两元素差不超过M的子段 首先会想到双指针维护(尺取法),如果p1,p2间的max-min>M,那么p1向右移动,直到p1,p2间的max-min&g ...
 - 前x个数据中至少有m个元素最小值与最大值之差不超过K
		
题意 给一组数据,从左到右开始,寻找最小的x,使得第1个元素到第x个元素中,至少存在m个数据,最小值与最大值之差不超过K. INPUT 第一行是T,代表数据组数 每组数据的第一行是三个整数,n.m.k ...
 - [LeetCode] Max Sum of Rectangle No Larger Than K 最大矩阵和不超过K
		
Given a non-empty 2D matrix matrix and an integer k, find the max sum of a rectangle in the matrix s ...
 - Codeforces Round #466 (Div. 2) A. Points on the line[数轴上有n个点,问最少去掉多少个点才能使剩下的点的最大距离为不超过k。]
		
A. Points on the line time limit per test 1 second memory limit per test 256 megabytes input standar ...
 - Leetcode 363.矩形区域不超过k的最大数值和
		
矩形区域不超过k的最大数值和 给定一个非空二维矩阵 matrix 和一个整数 k,找到这个矩阵内部不大于 k 的最大矩形和. 示例: 输入: matrix = [[1,0,1],[0,-2,3]], ...
 - [LeetCode] 363. Max Sum of Rectangle No Larger Than K 最大矩阵和不超过K
		
Given a non-empty 2D matrix matrix and an integer k, find the max sum of a rectangle in the matrix s ...
 
随机推荐
- login 模块,re 模块
			
标准三流 标准输入流:sys. stdin # input的底层 标准输出流:sys. stdout # print的底层 标准错误流:sys. stderr # 异常及loggin ...
 - 隐蔽的bean没有定义错误:No bean named 'SysJdTypeServiceImpl' is defined
			
org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'SysJdTypeServiceImpl ...
 - (5.9)mysql高可用系列——正常主从切换测试
			
[0]实验环境 操作系统:CentOS linux 7.5 数据库版本:5.7.24 数据库架构:主从复制,主库用于生产,从库用于数据容灾和主库备机,采用默认传统的异步复制. 主库IP:192.168 ...
 - 解决远程连不到CentOS7虚拟机或ifconfig中没有ens33
			
在使用Secure CRT连接虚拟机连接不上,可能之前虚拟机关闭不当 登到虚拟机的中断使用ifconfig发现没有ens33 猜测是CentOS图形管理中的NetworkManager接管了网络配置, ...
 - oracle 重置密码(一般电网,国企需要的二级等保)
			
oracle 10g,11g 可以查找以下,12c没有测试 一.查看profile配置并记录;二.在重置密码之前修改profile(PASSWORD_REUSE_MAX.PASSWORD_REUSE_ ...
 - 简单搭建http服务器-HttpListener使用
			
使用HTTPListener可以简单搭建一个Http服务器,对于本地使用很是方面,想起之前使用了WebSocket来与本地网页通讯的例子,也是可以改为使用HTTPListener来做的.看下HTTPL ...
 - debezium关于cdc的使用(上)
			
博文原址:debezium关于cdc的使用(上) 简介 debezium是一个为了捕获数据变更(cdc)的开源的分布式平台.启动并指向数据库,当其他应用对此数据库执行inserts.updates.d ...
 - mysql设计与优化以及数据库表设计与表开发规范
			
一.设计问题? 1.主键是用自增还是UUID ? Innodb 中的主键是聚簇索引. 如果主键是自增的,那么每次插入新的记录,记录就会顺序添加到当前索引节点的后续位置,当一页写满,就会自动开辟一个新的 ...
 - 一文搞懂网络知识,IP、子网掩码、网关、DNS、端口号
			
网络的基本概念 客户端:应用 C/S(客户端/服务器) B/S(浏览器/服务器) 服务器:为客户端提供服务.数据.资源的机器 请求:客户端向服务器索取数据 响应:服务器对客户端请求作出反应,一般是返回 ...
 - call,apply,bind的理解
			
call,apply,bind均是用于改变this指向. 三者相似之处: 1:都是用于改变函数的this指向. 2:第一个参数都是this要指向的对象. 3:都可以通过后面的参数进行对方法的传参. l ...