传送门

题意:

思路: 算是个整体二分的板子啦,不过这个是二维的矩阵,我们只需要把一位树状数组改成二维的,让后动态维护单点加,区间查询前缀和即可。

//#pragma GCC optimize(2)
#include<cstdio>
#include<iostream>
#include<string>
#include<cstring>
#include<map>
#include<cmath>
#include<cctype>
#include<vector>
#include<set>
#include<queue>
#include<algorithm>
#include<sstream>
#include<ctime>
#include<cstdlib>
#define X first
#define Y second
#define L (u<<1)
#define R (u<<1|1)
#define pb push_back
#define mk make_pair
#define Mid (tr[u].l+tr[u].r>>1)
#define Len(u) (tr[u].r-tr[u].l+1)
#define random(a,b) ((a)+rand()%((b)-(a)+1))
#define db puts("---")
#define lowbit(x) ((x)&(-x))
using namespace std;//void rd_cre() { freopen("d://dp//data.txt","w",stdout); srand(time(NULL)); }
//void rd_ac() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//AC.txt","w",stdout); }
//void rd_wa() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//WA.txt","w",stdout); }typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int,int> PII;const int N=1000010,mod=1e9+7,INF=0x3f3f3f3f;
const double eps=1e-6;int n,m;
int a[N],tot,ans[N];
int tr[510][510];
struct Node
{int x1,y1,val,op,x2,y2,id;
}q[N],q1[N],q2[N];void add(int x,int y,int c)
{for(int i=x;i<=n;i+=lowbit(i))for(int j=y;j<=n;j+=lowbit(j))tr[i][j]+=c;
}int sum(int x,int y)
{int ans=0;for(int i=x;i;i-=lowbit(i))for(int j=y;j;j-=lowbit(j))ans+=tr[i][j];return ans;
}int get_sub(int x1,int y1,int x2,int y2)
{int ans=0;ans+=sum(x2,y2);ans+=sum(x1-1,y1-1);ans-=sum(x1-1,y2);ans-=sum(x2,y1-1);return ans;
}void solve(int l,int r,int left,int right)
{if(l>r||left>right) return;if(l==r){for(int i=left;i<=right;i++) if(q[i].op==2) ans[q[i].id]=a[l];return;}int mid=l+r>>1;int cnt1,cnt2; cnt1=cnt2=0;for(int i=left;i<=right;i++){if(q[i].op==1){if(q[i].val<=a[mid]) add(q[i].x1,q[i].y1,1),q1[++cnt1]=q[i];else q2[++cnt2]=q[i];}else{int s=get_sub(q[i].x1,q[i].y1,q[i].x2,q[i].y2);if(q[i].val<=s) q1[++cnt1]=q[i];//别写错符号!else q[i].val-=s,q2[++cnt2]=q[i];}}for(int i=1;i<=cnt1;i++) if(q1[i].op==1) add(q1[i].x1,q1[i].y1,-1);for(int i=1;i<=cnt1;i++) q[i+left-1]=q1[i];for(int i=1;i<=cnt2;i++) q[left+cnt1+i-1]=q2[i];solve(l,mid,left,left+cnt1-1); solve(mid+1,r,left+cnt1,right);
}int main()
{//  ios::sync_with_stdio(false);
//  cin.tie(0);scanf("%d%d",&n,&m);for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) { int x; scanf("%d",&x); q[++tot]={i,j,x,1}; a[tot]=x; }sort(a+1,a+1+n*n);for(int i=1;i<=m;i++){int x1,y1,x2,y2,k; scanf("%d%d%d%d%d",&x1,&y1,&x2,&y2,&k);q[++tot]={x1,y1,k,2,x2,y2,i};}solve(1,n*n,1,tot);for(int i=1;i<=m;i++) printf("%d\n",ans[i]);return 0;
}
/**/

P1527 [国家集训队]矩阵乘法 整体二分 + 二维树状数组相关推荐

  1. BZOJ.2738.矩阵乘法(整体二分 二维树状数组)

    题目链接 BZOJ 洛谷 整体二分.把求序列第K小的树状数组改成二维树状数组就行了. 初始答案区间有点大,离散化一下. 因为这题是一开始给点,之后询问,so可以先处理该区间值在l~mid的修改,再处理 ...

  2. 洛谷P1527 [国家集训队] 矩阵乘法 [整体二分,二维树状数组]

    题目传送门 矩阵乘法 题目描述 给你一个N*N的矩阵,不用算矩阵乘法,但是每次询问一个子矩形的第K小数. 输入输出格式 输入格式: 第一行两个数N,Q,表示矩阵大小和询问组数: 接下来N行N列一共N* ...

  3. jzoj2908,P1527-[集训队互测 2012]矩阵乘法【整体二分,二维树状数组】

    正题 题目链接:https://www.luogu.org/problem/P1527 题目大意 给出一个矩阵,每个询问求子矩阵中的第kkk小数. 解题思路 我们发现我们对于每个询问我们可以二分答案, ...

  4. P1527 [国家集训队]矩阵乘法

    P1527 [国家集训队]矩阵乘法 题意: 给你一个 n×n 的矩阵,每次询问一个子矩形的第 k 小数. 题解: 整体二分稍微加强化 模板题是一个序列,现在升级成一个矩阵求,做法和原理都是一样的 使用 ...

  5. 洛谷1527(bzoj2738)矩阵乘法——二维树状数组+整体二分

    题目:https://www.luogu.org/problemnew/show/P1527 不难想到(?)可以用二维树状数组.但维护什么?怎么查询是难点. 因为求第k小,可以考虑记权值树状数组,把比 ...

  6. 【二维树状数组】See you~

    https://www.bnuoj.com/v3/contest_show.php?cid=9148#problem/F [题意] 给定一个矩阵,每个格子的初始值为1.现在可以对矩阵有四种操作: A ...

  7. szu 寒训第二天 树状数组 二维树状数组详解,以及树状数组扩展应用【求逆序对,以及动态第k小数】

    树状数组(Binary Index Tree) 树状数组可以解决可以转化为前缀和问题的问题 这是一类用以解决动态前缀和的问题 (有点像线段树简版) 1.对于 a1 + a2 + a3 + - + an ...

  8. 海啸(二维前缀和/二维树状数组)

    链接:https://ac.nowcoder.com/acm/problem/21862 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...

  9. HDU - 5517 Triple(三维偏序-二维树状数组/CDQ分治)

    题目链接:点击查看 题目大意:给出 n 个二元对 ( a , b ) 和 m 个三元对 ( c , d , e ),对于所有 b == e 的二元对和三元对,可以通过某种运算形成一个新的三元对 ( a ...

最新文章

  1. 计算机图形学直线扫描转论文,计算机图形学实验报告-实验1直线段扫描转换.doc...
  2. Rabbitmq-理论基础
  3. 中国700万程序员不够用怎么办?我们去问了北大谢涛,顶会ASE最有影响力论文奖首批华人得主...
  4. python之控制流习题+代码
  5. Android中使用ContentProvider进行跨进程方法调用
  6. 传输预编码matlab,基于MATLAB的MIMO系统预编码性能仿真教程.doc
  7. 局内网用户访问wamp本地站点
  8. 关于centos docker版本过低导致 is not a valid repository/tag: invalid reference format
  9. dos命令配置jdk环境
  10. 单线程写多线程读安全的结构体
  11. unserialize用法
  12. php商城关键字拆词搜索,做搜索查询的时候 怎么拆分词?
  13. oracle 某一字段取反
  14. 机器学习的数学(三)范数的简单介绍
  15. 一、配置etcd数据库
  16. EF+MYSQL 闪退
  17. java基础篇---第一天
  18. 微信小程序实现星星评分
  19. JAVA spring hessian_Springboot写的Hessian例子
  20. 【BSP视频教程】STM32H7视频教程第3期:整体捋顺STM32H7的HAL库和LL库的框架,再配合寄存器造轮子找到更适合自己的玩法(2022-01-21)

热门文章

  1. 美少女什么味??竟然还有美少女风味泡面......
  2. 为什么说,每个人都应该多读些书?
  3. 新世纪英汉词典 | 今日最佳
  4. 这6个动作,据说只有20%的人能做到!| 今日最佳
  5. 每日一笑 | 对不起,我还没下班...
  6. 2019最佳年会,新东方6名员工冒着离职的风险,在年会上怒怼老板
  7. 关于机器学习,你应该至少学习这8个落地案例|干货集锦
  8. python赋值语句格式_Python赋值语句后逗号的作用分析
  9. java号段_JAVA手机号正则(多号段)
  10. java spring 单例模式,spring中的单例模式