博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JDOJ-最小面积子矩阵 暴力(排斥二分)
阅读量:5740 次
发布时间:2019-06-18

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

这题就是求一个矩阵中的最小面积矩阵,使得其和大于一个给定的K,由于是求最优解,所以很自然的想到了二分查找这个值,但是这题我却在不去顶是否满足二分性质的前提下匆忙的选择了二分查找,最终导致了错误。原因在与当一个面积为一个最优解的时候,面积大于该最优解的子矩阵不一定包含这个最优矩阵,例如一个5*5的矩阵的,如果最优矩阵是一个2*2的矩阵,那么1*5的面积为5的矩阵式不会包含这个2*2的矩阵的,所以......

代码如下:

#include 
#include
#include
#include
#define MAXN 105using namespace std;int N, M, K, G[MAXN][MAXN], S[MAXN*MAXN], lim;int rec[MAXN*MAXN], idx, sum[MAXN][MAXN];struct Node{ int x, y;}que[MAXN];int front, tail;inline void pre(){ int k; lim = N*M; memset(S, 0, sizeof (S)); idx = -1; // getstatus for (int i = 1; i <= N; ++i) { k = min(M, lim / i); // 选取相对小的值,排除不合法情况 for (int j = 1; j <= k; ++j) { S[i*j] = 1; } } for (int i = 1; i <= lim; ++i) { if (S[i]) { rec[++idx] = i; } } // getsum for (int i = 1; i <= N; ++i) { for (int j = 1; j <= M; ++j) { sum[i][j] = sum[i-1][j] + sum[i][j-1] - sum[i-1][j-1] + G[i][j]; } }}bool judge(){ int xx, yy, zz, lx, ly; for (int k = 1; k <= tail; ++k) { lx = N - que[k].x + 1, ly = M - que[k].y + 1; for (int i = 1; i <= lx; ++i) { for (int j = 1; j <= ly; ++j) { xx = i+que[k].x-1, yy = j+que[k].y-1; if (xx <= N && yy <= M) { zz = sum[xx][yy] - sum[i-1][yy] - sum[xx][j-1] + sum[i-1][j-1]; if (zz >= K) return true; } } } } return false;}bool Ac(int x) // 能够保证所有的x都是合法值 { front = tail = 0; for (int i = 1; i <= N; ++i) { if (x % i == 0) { ++tail; que[tail].x = i, que[tail].y = x / i; } } // 处理处当前面积的分解情况 if (judge()) { return true; } return false;}int bsearch(int l, int r){ int mid, ret = -1; while (l <= r) { mid = (l + r) >> 1; if (Ac(rec[mid])) { ret = rec[mid]; r = mid - 1; } else { l = mid + 1; } } return ret;}int force(){ for (int i = 0; i <= idx; ++i) { if (Ac(rec[i])) { return rec[i]; } } return -1;}int main(){ while (scanf("%d %d %d", &N, &M, &K) != EOF) { for (int i = 1; i <= N; ++i) { for (int j = 1; j <= M; ++j) { scanf("%d", &G[i][j]); } } pre(); // printf("%d\n", bsearch(0, idx)); printf("%d\n", force()); } return 0; }

转载于:https://www.cnblogs.com/Lyush/archive/2012/08/23/2652951.html

你可能感兴趣的文章
Windows Phone 7 隔离存储空间资源管理器
查看>>
Microsoft Excel 2000/2003修复工具
查看>>
apache安装报错undefined reference ssl
查看>>
关于爱情只有一句忠告
查看>>
CentOS 7下安装部署Oracle11g图文教程
查看>>
F#初学笔记06
查看>>
实战:将企业域名解析委派给企业DNS服务器
查看>>
在Lync 2013环境部署Office Web Apps
查看>>
微软大会Ignite,你准备好了么?
查看>>
读书笔记-高标管事 低调管人
查看>>
Master带给世界的思考:是“失控”还是进化
查看>>
用户和开发者不满苹果iCloud问题多多
查看>>
attrs.xml中declare-styleable 详解(用于自定义控件的属性)
查看>>
java.lang.UnsatisfiedLinkError:no dll in java.library.path终极解决之道
查看>>
错误“Unexpected namespace prefix "xmlns" found for tag LinearLayout”的解决方法(转)
查看>>
我的工具:文本转音频文件
查看>>
【许晓笛】从零开始运行EOS系统
查看>>
【跃迁之路】【460天】程序员高效学习方法论探索系列(实验阶段217-2018.05.11)...
查看>>
C++入门读物推荐
查看>>
TiDB 源码阅读系列文章(七)基于规则的优化
查看>>