Codeforces 869E. The Untended Antiquity

题意:

在一张mxn的格子纸上,进行q次操作:

1,指定一个矩形将它用栅栏围起来。

2,撤掉一个已有的栅栏。

3,询问指定两点之间是否连通(即能否从其中一点不翻越栅栏走到另一点)

思路:

对于操作1,将给定的矩形哈希成一个数(可对点坐标进行进制哈希),对整个矩形所覆盖的点都累加上这个数;

对于操作2,则逆着把操作1的影响抵消掉;

对于操作3,看一下两点的值是否相同(相同表示他们被相同的矩形们所覆盖)。

至于每次矩形内的所有点的修改操作以及单点查值,使用二维树状数组来维护,用到了差分思想,维护的是差分数组,则单点查询即求差分数组的前缀和。具体可见代码,在图上画一画,不难理解

代码:

  1. #include<bits/stdc++.h>
  2. #define de(x) cout<<#x<<" = "<<x<<"\n"
  3. #define dd(x) cout<<#x<<" = "<<x<<" "
  4. #define sz(x) int(x.size())
  5. #define All(x) x.begin(),x.end()
  6. #define fi first
  7. #define se second
  8. #define pb push_back
  9. #define mp make_pair
  10. using namespace std;
  11. typedef long long ll;
  12. typedef long double ld;
  13. typedef pair<int,int> P;
  14. typedef priority_queue<int> BQ;
  15. typedef priority_queue<int,vector<int>,greater<int> > SQ;
  16. const int maxn=3e3+10,INF=0x3f3f3f3f;
  17. ll fw[maxn][maxn];
  18. void add(int x,int y,ll c)
  19. {
  20. for (int i=x;i<maxn;i+=i&-i)
  21. for (int j=y;j<maxn;j+=j&-j)
  22. fw[i][j]+=c;
  23. }
  24. ll qry(int x,int y)
  25. {
  26. ll res=0;
  27. for (int i=x;i;i-=i&-i)
  28. for (int j=y;j;j-=j&-j)
  29. res+=fw[i][j];
  30. return res;
  31. }
  32. ll seed=2333;
  33. inline ll Hash(int a,int b,int c,int d)
  34. {
  35. return a*seed*seed*seed+b*seed*seed+c*seed+d;
  36. }
  37. int main()
  38. {
  39. int n,m,q;
  40. cin>>n>>m>>q;
  41. for (int i=0;i<q;++i)
  42. {
  43. int op,x1,y1,x2,y2;
  44. scanf("%d%d%d%d%d",&op,&x1,&y1,&x2,&y2);
  45. if (op==3)
  46. {
  47. if (qry(x1,y1)==qry(x2,y2))
  48. printf("Yes\n");
  49. else
  50. printf("No\n");
  51. }
  52. else
  53. {
  54. ll hs=Hash(x1,y1,x2,y2);
  55. if (op==2)
  56. hs=-hs;
  57. add(x1,y1,hs);
  58. add(x2+1,y2+1,hs);
  59. add(x1,y2+1,-hs);
  60. add(x2+1,y1,-hs);
  61. }
  62. }
  63. return 0;
  64. }

Codeforces 869E. The Untended Antiquity (二维Fenwick,Hash)的更多相关文章

  1. Codeforces 869E The Untended Antiquity

    题意:给定一个网格图,三种操作:1.在(r1,c1,r2,c2)处建围墙.2.删除(r1,c1,r2,c2)处的围墙.3.询问两点是否可达 思路比较巧妙,将围墙内的点赋加一个权值,询问的时候判断两个点 ...

  2. URAL - 1486 二维字符串HASH

    题目链接:http://acm.timus.ru/problem.aspx?space=1&num=1486 题意:给定一个n*m的字符矩阵,问你是否存在两个不重合(可以有交集)的正方形矩阵完 ...

  3. 【算法系列学习】codeforces D. Mike and distribution 二维贪心

    http://codeforces.com/contest/798/problem/D http://blog.csdn.net/yasola/article/details/70477816 对于二 ...

  4. CodeForces 242E - XOR on Segment 二维线段树?

    今天练习赛的题....又是线段树的变换..拿到题我就敲了个点更新区间查询的..果断超时...然后想到了可以将每个数与合表示成不进位的二进制数..这样就可以区间进行更新了..比赛的时候写搓了..刚重写了 ...

  5. Codeforces 1080C 题解(思维+二维前缀和)

    题面 传送门 题目大意: 有一个黑白的棋盘,现在将棋盘上的一个子矩形全部染成黑色,另一个子矩形全部染成白色 求染完色后黑,白格子的总数 分析 我们可以发现,对于一个(1,1)到(x,y)的矩形,若xy ...

  6. Codeforces Round #578 (Div. 2) 二维差分 可做模板

    题意: 在n*n的矩阵中,你可以选择一个k*k的子矩阵,然后将这个子矩阵中的所有B全部变为W,问你怎么选择这个子矩阵使得最终的矩阵中某一行全是W或者某一列全是W的个数最多 题解:考虑每一行和每一列,对 ...

  7. Codeforces 798D - Mike and distribution(二维贪心、(玄学)随机排列)

    题目链接:http://codeforces.com/problemset/problem/798/D 题目大意:从长度为n的序列A和序列B中分别选出k个下表相同的数要求,设这两个序列中k个数和分别为 ...

  8. Codeforces#514D(三分,简单二维几何)

    #include<bits/stdc++.h>using namespace std;const double eps=1e-8;int n; struct node{    double ...

  9. 牛客网训练1--------矩阵 (二份+二维矩阵hash)

    不懂hash的话:https://www.cnblogs.com/ALINGMAOMAO/p/10345850.html 思路:对于一个大矩阵的每一个子矩阵都对应着一个hash值k, 当k出现2次以上 ...

随机推荐

  1. Linux 系统的安全加固

    Linux是一套免费使用和自由传播的类Unix操作系统,作为一个开放源代码的操作系统,Linux服务器以其安全.高效和稳定的显著优势而得以广泛应用,但如果不做好权限的合理分配,Linux系统的安全性还 ...

  2. 有关this指针指向问题

    在下面两个写法中 var obj = { foo: function () {} }; var foo = obj.foo; // 写法一 obj.foo() // 写法二 foo() 上面代码中,虽 ...

  3. 错误:The following error occurred attempting to run the DNX design time process (dnx-clr-win-x86.1.0.0-rc1-final)

    其实这个错误很容易解决.设置一个startup工程即可.

  4. 【原型模式】--重写原型对象prototype的影响

    //[原型模式]--重写原型对象prototype的影响 2014-12-12//定义构造函数function Person() { }//直接指定构造函数的原型为一个对象(为了简化逐个给原型添加成员 ...

  5. luogu1731生日蛋糕题解--恶心剪枝

    题目链接 https://www.luogu.org/problemnew/show/P1731 分析 这题真[哔]恶心,加了一堆奇奇怪怪的优化 首先明确一点,半径和高都必须是正整数,意味着它们最小为 ...

  6. 使用nodejs创建Marketing Cloud的contact数据

    源代码如下: var config = require("./mcConfig"); var request = require('request'); var url = con ...

  7. bootsctrap4 datepicker时间选择插件

    现在网上基本都是v3的时间选择插件,花了点时间改了找了个v4能用的 bootstrap-datepicker <!DOCTYPE html> <html> <head&g ...

  8. 分布式任务队列 Celery —— Task对象

    转载至 JmilkFan_范桂飓:http://blog.csdn.net/jmilk  目录 目录 前文列表 前言 Task 的实例化 任务的名字 任务的绑定 任务的重试 任务的请求上下文 任务的继 ...

  9. 《数据结构与算法之美》 <01>复杂度分析(上):如何分析、统计算法的执行效率和资源消耗?

    我们都知道,数据结构和算法本身解决的是“快”和“省”的问题,即如何让代码运行得更快,如何让代码更省存储空间.所以,执行效率是算法一个非常重要的考量指标. 那如何来衡量你编写的算法代码的执行效率呢?这里 ...

  10. Linux学习笔记(五)Linux常用命令:压缩命令

    Linux中最常见的5中压缩格式: zip gz bz2 tar.gz tar.bz2 一..zip压缩命令 压缩文件 zip [压缩文件名] [源文件] 例如: zip zijeak.zip zij ...