P4054 [JSOI2009]计数问题

题目描述

一个n*m的方格,初始时每个格子有一个整数权值。接下来每次有2种操作:

  • 改变一个格子的权值;
  • 求一个子矩阵中某种特定权值出现的个数。

输入输出格式

输入格式:

第一行有两个数N,M。

接下来N行,每行M个数,第i+1行第j个数表示格子(i,j)的初始权值。

接下来输入一个整数Q。

之后Q行,每行描述一个操作。

操作1:“1 x y c”(不含双引号)。表示将格子(x,y)的权值改成c(1<=x<=n,1<=y<=m,1<=c<=100)。

操作2:“2 x1 x2 y1 y2 c”(不含双引号,x1<=x2,y1<=y2)。表示询问所有满足格子颜色为c,且x1<=x<=x2,y1<=y<=y2的格子(x,y)的个数。

输出格式:

对于每个操作2,按照在输入中出现的顺序,依次输出一行一个整数表示所求得的个数。

二维树状数组模板题。

二维树状数组的操作:

  1. void add(int posx,int posy,int k){
  2. for(int i=posx;i<=n;i+=(i&-i)){
  3. for(int j=posy;j<=m;j+=(j&-j)){
  4. sum[i][j]+=k;
  5. }
  6. }
  7. }
  1. int query(int posx,int posy){
  2. int re=0;
  3. for(int i=posx;i>=1;i-=(i&-i)){
  4. for(int j=posy;j>=1;j-=(j&-j)){
  5. re+=sum[i][j];
  6. }
  7. }
  8. return re;
  9. }

对于此题,按照权值开树状数组,封装一下,每一次模拟操作即可。

code:

  1. #include <iostream>
  2. #include <cstdio>
  3. using namespace std;
  4. const int wx=307;
  5. inline int read(){
  6. int sum=0,f=1; char ch=getchar();
  7. while(ch<'0'||ch>'9'){if(ch=='-')f=-1; ch=getchar();}
  8. while(ch>='0'&&ch<='9'){sum=(sum<<1)+(sum<<3)+ch-'0'; ch=getchar();}
  9. return sum*f;
  10. }
  11. int n,m;
  12. int q;
  13. int a[wx][wx];
  14. struct BIT{
  15. int sum[wx][wx];
  16. void add(int posx,int posy,int k){
  17. for(int i=posx;i<=n;i+=(i&-i)){
  18. for(int j=posy;j<=m;j+=(j&-j)){
  19. sum[i][j]+=k;
  20. }
  21. }
  22. }
  23. int query(int posx,int posy){
  24. int re=0;
  25. for(int i=posx;i>=1;i-=(i&-i)){
  26. for(int j=posy;j>=1;j-=(j&-j)){
  27. re+=sum[i][j];
  28. }
  29. }
  30. return re;
  31. }
  32. }t[wx];
  33. int main(){
  34. n=read(); m=read();
  35. for(int i=1;i<=n;i++){
  36. for(int j=1;j<=m;j++){
  37. cin>>a[i][j];
  38. t[a[i][j]].add(i,j,1);
  39. }
  40. }
  41. q=read();
  42. for(int i=1;i<=q;i++){
  43. int opt;
  44. opt=read();
  45. if(opt==1){
  46. int x,y,c;
  47. x=read(); y=read(); c=read();
  48. t[a[x][y]].add(x,y,-1);
  49. t[c].add(x,y,1);
  50. a[x][y]=c;
  51. }
  52. else{
  53. int x1,x2,y1,y2,c;
  54. x1=read(); x2=read(); y1=read(); y2=read(); c=read();
  55. printf("%d\n",t[c].query(x2,y2)-t[c].query(x1-1,y2)-t[c].query(x2,y1-1)+t[c].query(x1-1,y1-1));
  56. }
  57. }
  58. return 0;
  59. }

模板:二维树状数组 【洛谷P4054】 [JSOI2009]计数问题的更多相关文章

  1. 洛谷P4054 [JSOI2009]计数问题(二维树状数组)

    题意 题目链接 Sol 很傻x的题.. c才100, n, m才300,直接开100个二维树状数组就做完了.. #include<bits/stdc++.h> using namespac ...

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

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

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

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

  4. 二维树状数组总结&&【洛谷P4514】 上帝造题的七分钟

    P4514 上帝造题的七分钟 题目描述 "第一分钟,X说,要有矩阵,于是便有了一个里面写满了00的n×mn×m矩阵. 第二分钟,L说,要能修改,于是便有了将左上角为(a,b)(a,b),右下 ...

  5. 洛谷P1527 矩阵乘法——二维树状数组+整体二分

    题目:https://www.luogu.org/problemnew/show/P1527 整体二分,先把所有询问都存下来: 然后二分一个值,小于它的加到二维树状数组的前缀和里,判断一遍所有询问,就 ...

  6. 洛谷 P2038 无线网络发射器选址 —— 二维树状数组

    题目:https://www.luogu.org/problemnew/show/P2038 大水题暴露出我的愚蠢. 用二维树状数组,然而居然忘了它应该那样写,调了一个小时: 正方形可以超出外面,只要 ...

  7. POJ 2029 Get Many Persimmon Trees (模板题)【二维树状数组】

    <题目链接> 题目大意: 给你一个H*W的矩阵,再告诉你有n个坐标有点,问你一个w*h的小矩阵最多能够包括多少个点. 解题分析:二维树状数组模板题. #include <cstdio ...

  8. hdu 2642二维树状数组 单点更新区间查询 模板题

    二维树状数组 单点更新区间查询 模板 从零开始借鉴http://www.2cto.com/kf/201307/227488.html #include<stdio.h> #include& ...

  9. hdu 2642 二维树状数组 单点更新区间查询 模板水题

    Stars Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/65536 K (Java/Others) Total Subm ...

随机推荐

  1. ManualResetEvent 用法

    第一.简单介绍 ManualResetEvent 允许线程通过发信号互相通信.通常,此通信涉及一个线程在其他线程进行之前必须完成的任务.当一个线程开始一个活动(此活动必须完成后,其他线程才能开始)时, ...

  2. Python No module named pkg_resources

    好记性不如烂笔头. I encountered the same ImportError today while trying to use pip. Somehow the setuptools p ...

  3. Ettercap进行arp毒化

    攻击者IP:192.168.220.152 受害者IP:192.168.220.151 网关:192.168.220.2 修改DNS文件 ┌─[root@sch01ar]─[~] └──╼ #vim ...

  4. linux下mysql 最新版安装图解教程

    1.查看当前安装的linux版本 命令:lsb_release -a 如下图所示 通过上图中的数据可以看出安装的版本为RedHat5.4,所以我们需要下载RedHat5.4对应的mysql安装包 2. ...

  5. oracle错误-ORA-12519, TNS:no appropriate service handler found

    转自:https://blog.csdn.net/u013147600/article/details/48380841

  6. chosen.jquery插件的使用

    前几天在jQuery官网看到了插件里面有400多个插件,看了下效果都很好,以后项目里面难免会用到.于是下了个决定,有时间把官网的插件都研究下,并简单介绍他的用法,方便以后的使用. 下面将要提到的是jQ ...

  7. git 本地代码到github(转)

    git 本地代码到github   一·什么是gitHub? 官网解释:gitHub是一个让无论处于何地的代码工作者能工作于同一个项目,同一个版本的平台.(GitHub is a code hosti ...

  8. linux中创建图片服务器减轻传统服务器的压力

    1.1.   传统项目中的图片管理 传统项目中,可以在web项目中添加一个文件夹,来存放上传的图片.例如在工程的根目录WebRoot下创建一个images文件夹.把图片存放在此文件夹中就可以直接使用在 ...

  9. C#调用C++类库的几种方式

    1.  直接调用C++类库中的公共方法 使用DllImport特性对方法进行调用,比如一个C++类库SampleCppWrapper.dll中的公共方法: extern "C" _ ...

  10. R: 正则表达式

    正则表达式: 例:sub("a","",c("abcd","dcba")):   [1] "bcd" ...