博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
fzu 2056(二分查找)
阅读量:6124 次
发布时间:2019-06-21

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

这题的关键是矩阵中的每个元素都是 >=0 的, 然后就可以找到递增性质. 也就是如果N*N个方块满足小于或等于limit 那么(N-1)*(N-1)个方块也是满足的.

 

Problem 2056 最大正方形

Accept: 75    Submit: 287
Time Limit: 1000 mSec    Memory Limit : 32768 KB

Problem Description

现在有一个n*m的矩阵A,在A中找一个H*H的正方形,使得其面积最大且该正方形元素的和不大于 limit。

Input

第一行一个整数T,表示有T组数据。

每组数据 第一行三个非负整数 n m limit

接着 n 行,每行 m 个整数。

 

0 < n <= 1000, 0 < m <= 1000, 0 <= limit <=100000000 0 <= A[i] <= 1000

Output

对于每组数据,输出H*H。

Sample Input

2 2 2 2 1 1 1 1 2 2 4 1 1 1 1

Sample Output

1 4

Source

FOJ有奖月赛-2011年11月
#include 
#include
#include
#include
using namespace std;#define N 1010int dp[N][N]; //存前i,j矩阵的和int n,m,lm;int fuc(int s){ if(s==0) return 1; for(int i=s;i<=n;i++) for(int j=s;j<=m;j++) { int sum=dp[i][j]-dp[i-s][j]-dp[i][j-s]+dp[i-s][j-s]; if(sum<=lm) { return 1; } } return 0;}int main(){ int t; scanf("%d",&t); while(t--) { scanf("%d%d%d",&n,&m,&lm); memset(dp,0,sizeof(dp)); for(int i=1;i<=n;i++) { int sum=0; for(int j=1;j<=m;j++) { int tmp; scanf("%d",&tmp); sum+=tmp; dp[i][j]=dp[i-1][j]+sum; } } int b=0,d=min(n,m); while(b

 

转载地址:http://ldgka.baihongyu.com/

你可能感兴趣的文章
程序员眼中的 SQL Server-执行计划教会我如何创建索引?
查看>>
【BZOJ】1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路(floyd)
查看>>
cmake总结
查看>>
数据加密插件
查看>>
linux后台运行程序
查看>>
win7 vs2012/2013 编译boost 1.55
查看>>
IIS7如何显示详细错误信息
查看>>
C++文件读写详解(ofstream,ifstream,fstream)
查看>>
Android打包常见错误之Export aborted because fatal lint errors were found
查看>>
Tar打包、压缩与解压缩到指定目录的方法
查看>>
新手如何学习 jQuery?
查看>>
配置spring上下文
查看>>
Python异步IO --- 轻松管理10k+并发连接
查看>>
mysql-python模块编译问题解决
查看>>
Oracle中drop user和drop user cascade的区别
查看>>
【Linux】linux经常使用基本命令
查看>>
HTML模块化:使用HTML5 Boilerplate模板
查看>>
登记申请汇总
查看>>
Google最新截屏案例详解
查看>>
2015第31周日
查看>>