可以用二维树状数组套值域线段树来做,复杂度:O( (n*n+q) * logn logn log10^9 )

但作为作为整体二分的例题,还是用整体二分来写了一下。对整体二分有一点感觉了。

整体二分,顾名思义,二分答案,只不过不是对单独一个询问,而是对所有询问,具体过程可以想象成对询问的不断分类(根据其答案区间不断往下分)。比如最开始所有询问的答案区间是[amin,amax],我们现在分出两个区间[amin,amid],和[amid+1,amax],然后将当前区间[amin,amax]的所有询问根据某些信息,分配到两个区间,使得其答案的可能的区间范围就是它所属的区间,当区间长度为1时,该区间包含的询问的答案就是该区间的那个数。

形象一点,可以把二分比作赶鸭子(询问)回窝(答案),单独对一个询问二分是只赶一只鸭子,向左区间或右区间赶,直到回窝,而整体二分就是赶一群鸭子,前者只需单刀直入,找到答案,而后者还需要回朔。

整体二分的优势是可以在分配询问时共享一些东西,从而避免掉每次单独算的低效,从而优化复杂度。

 #include <cstdio>
#include <vector>
#include <algorithm>
#define oo 0x3f3f3f3f
#define N 510
#define M 60010
using namespace std; struct Pair {
int v;
int x, y;
Pair(){}
Pair( int v, int x, int y ):v(v),x(x),y(y){}
bool operator<( const Pair &o ) const {
return v<o.v;
}
};
bool operator<( const Pair &a, int b ) {
return a.v<b;
}
bool operator<( int a, const Pair &b ) {
return a<b.v;
}
struct Query {
int id;
int xmin, xmax;
int ymin, ymax;
int k;
Query( int id, int x0, int x1, int y0, int y1, int k ):
id(id),xmin(x0),xmax(x1),ymin(y0),ymax(y1),k(k){}
}; int n, m;
int ww[N][N], vmin, vmax;
int bit[N][N];
int ans[M];
Pair prs[N*N]; int ptot;
vector<Query> vq;
int q[N*N]; void modify( int x, int y, int v ) {
for( register int i=x; i<=n; i+=i&-i )
for( register int j=y; j<=n; j+=j&-j )
bit[i][j] += v;
}
int query( int x, int y ) {
int rt = ;
for( register int i=x; i; i-=i&-i )
for( register int j=y; j; j-=j&-j )
rt += bit[i][j];
return rt;
}
int query( int xmin, int xmax, int ymin, int ymax ) {
return query(xmax,ymax)-query(xmin-,ymax)-query(xmax,ymin-)+query(xmin-,ymin-);
}
void binary( int lf, int rg, vector<Query> vq ) {
if( vq.empty() ) return;
if( lf==rg ) {
for( int t=; t<vq.size(); t++ )
ans[vq[t].id] = lf;
return;
}
int mid=lf+((rg-lf)>>);
int lpos = lower_bound( prs+, prs++ptot, lf ) - prs;
int rpos = upper_bound( prs+, prs++ptot, mid ) - prs - ;
for( int i=lpos; i<=rpos; i++ )
modify( prs[i].x, prs[i].y, + );
vector<Query> ql, qr;
for( int t=; t<vq.size(); t++ ) {
int c = query( vq[t].xmin, vq[t].xmax, vq[t].ymin, vq[t].ymax );
if( vq[t].k<=c )
ql.push_back( vq[t] );
else {
qr.push_back( vq[t] );
qr.back().k -= c;
}
}
for( int i=lpos; i<=rpos; i++ )
modify( prs[i].x, prs[i].y, - );
binary( lf, mid, ql );
binary( mid+, rg, qr );
}
int main() {
scanf( "%d%d", &n, &m );
vmin=oo, vmax=-oo;
for( int i=; i<=n; i++ )
for( int j=; j<=n; j++ ) {
scanf( "%d", &ww[i][j] );
vmin = min( vmin, ww[i][j] );
vmax = max( vmax, ww[i][j] );
prs[++ptot] = Pair( ww[i][j], i, j );
}
sort( prs+, prs++ptot );
for( int i=,x0,x1,y0,y1,k; i<=m; i++ ) {
scanf( "%d%d%d%d%d", &x0, &y0, &x1, &y1, &k );
vq.push_back( Query( i, x0, x1, y0, y1, k ) );
}
binary( vmin, vmax, vq );
for( int i=; i<=m; i++ )
printf( "%d\n", ans[i] );
}

tsinsen A1333的更多相关文章

  1. Tsinsen A1333: 矩阵乘法(整体二分)

    http://www.tsinsen.com/A1333 题意:-- 思路:和之前的第k小几乎一样,只不过把一维BIT换成二维BIT而已.注意二维BIT写法QAQ #include <cstdi ...

  2. tsinsen A1333. 矩阵乘法(梁 盾)

    A1333. 矩阵乘法(梁 盾) 时间限制:2.0s   内存限制:256.0MB   总提交次数:515   AC次数:211   平均分:54.14   将本题分享到:        查看未格式化 ...

  3. tsinsen A1333. 矩阵乘法

    题目链接:传送门 题目思路:整体二分(二分的是答案,附带的是操作) 把矩阵中的元素对应成插入操作,然后就有插入和询问操作. 然后根据插入操作对于答案的影响,询问操作所匹配的符合答案个数,将操作分为两段 ...

  4. 整体二分learning

    整体二分是一个离线的做法  目前可以解决求区间第k大问题 当然划分树主席树都可以的样子.. 为什么我老学一些解决同种问题的算法.. 主要思想大概是这样的: 如果要求[l,r]的区间第K大 而这个区间内 ...

  5. 【BZOJ】【2738】&【Tsinsen】【A1333】矩阵乘法

    整体二分+树状数组 过了[BZOJ][2527][POI2011]Meteors以后这题就没那么难啦~ 关键是[从小到大]依次插入数字,然后整体二分每个查询的第k大是在第几次插入中被插入的……嗯大概就 ...

  6. Tsinsen A1493 城市规划(DP + CDQ分治 + NTT)

    题目 Source http://www.tsinsen.com/A1493 Description 刚刚解决完电力网络的问题, 阿狸又被领导的任务给难住了. 刚才说过, 阿狸的国家有n个城市, 现在 ...

  7. 【Tsinsen】【A1365】森林旅店

    KD-Tree 啊哈~检验了一下自己KD-Tree的学习情况,还算可以,模板至少是记下来了. 支持插入(所以要带重建),查询最近的P个点的距离. 然而题目并没有说是按怎样的顺序输出这P个点?...(事 ...

  8. Tsinsen A1219. 采矿(陈许旻) (树链剖分,线段树 + DP)

    [题目链接] http://www.tsinsen.com/A1219 [题意] 给定一棵树,a[u][i]代表u结点分配i人的收益,可以随时改变a[u],查询(u,v)代表在u子树的所有节点,在u- ...

  9. Tsinsen A1303. tree(伍一鸣) (LCT+处理标记)

    [题目链接] http://www.tsinsen.com/A1303 [题意] 给定一棵树,提供树上路径乘/加一个数,加边断边,查询路径和的操作. [思路] LCT+传标 一次dfs构造LCT. L ...

随机推荐

  1. Linux嵌入式交叉编译环境 的搭建【转】

    转自:http://blog.csdn.net/woaixiaozhe/article/details/7395435 1. 安装标准的C开发环境,由于Linux安装默认是不安装的,所以需要先安装一下 ...

  2. Memcache 内存分配策略和性能(使用)状态检查【转】

    前言: 一直在使用Memcache,但是对其内部的问题,如它内存是怎么样被使用的,使用一段时间后想看看一些状态怎么样?一直都不清楚,查了又忘记,现在整理出该篇文章,方便自己查阅.本文不涉及安装.操作. ...

  3. 忘记SVN密码怎么办

    1:下载TSvnPwd.exe 2:使用wireshark抓包.例如: PROPFIND /svn/dev2/!svn/vcc/default HTTP/1.1Host: 192.168.156.1: ...

  4. 解决insert语句插入时,需要写列值的问题

    今天发现解决这个问题其实很简单,闲话不多谈,我直接附上语句 ) select @s = isnull(@s+',', '') + [name] from syscolumns where id = o ...

  5. 20155309 2016-2017-2《Java程序设计》课程总结

    预备作业1http://www.cnblogs.com/nhx19970709/p/6155580.html 第一次写博客,也是第一次用Markdown,具体流程都还不是很熟悉 预备作业2http:/ ...

  6. 2015309南皓芯《Java程序设计》实验一(Java开发环境的熟悉)实验报告

    一.实验内容及步骤 (一)使用JDK编译.运行简单的java程序 命令行下的程序开发 步骤一(新建文件夹):打开windows下的cmd → 输入cd Code命令进入Code目录 → 输入md 20 ...

  7. 洛谷 P1992 不想兜圈的老爷爷 题解

    洛谷 P1992 不想兜圈的老爷爷 题解 题目描述 一位年过古稀的老爷爷在乡间行走 而他不想兜圈子 因为那会使他昏沉 偶然路过小A发扬助人为乐优良传统 带上地图 想知道路况是否一定使他清醒 usqwe ...

  8. .NetCore读取配置Json文件到类中并在程序使用

    ConfigurationBuilder 这个类提供了配置绑定,在dnc中 Program中WebHost提供了默认的绑定(appsettings文件) 如果我们需要加载我们自己的json配置文件怎么 ...

  9. Visual Studio 2017 发布 附带下载地址

    链接: https://pan.baidu.com/s/1kFjGwyj5HwabvmJKiyLF_g 提取码: 关注公众号[GitHubCN]回复获取    winform框架源码-Devexpre ...

  10. linux 101 hacks 2date,grep,find

    感觉挨个按着作者来的太蠢了,我还是放自己觉得不错的东西把 用特定格式显示当前时间 以下的方法可以用各种不同的格式来显示当前时间: $ date Thu Jan :: PST $ date --date ...