题目链接:hdu 5454 Excited Database

解题思路

维护两科线段树,一棵i+j,一棵i-j。因为对角线上的值一定都是相同的,只是查询时的个数不一样,但是根据区间范围可以计算出来每条对角线的个数。每个树维护单一节点权值和s,从右边递增的和r,从左边递增的和l。查询的时候将矩形分成3份。

代码

#include <cstdio>
#include <cstring>
#include <algorithm>using namespace std;
const int maxn = 400005;
typedef long long ll;
#define lson(x) ((x)<<1)
#define rson(x) (((x)<<1)|1)struct SegTree {int lc[maxn<<2], rc[maxn<<2];ll S[maxn<<2], L[maxn<<2], R[maxn<<2], T[maxn<<2];int length(int u) {return rc[u] - lc[u] + 1;}void maintain(int u, ll a) {T[u] += a;S[u] += a * length(u);ll add = a * (length(u) + 1) * length(u) / 2;L[u] += add;R[u] += add;}void pushup(int u) {S[u] = S[lson(u)] + S[rson(u)];L[u] = L[lson(u)] + L[rson(u)] + S[rson(u)] * length(lson(u));R[u] = R[rson(u)] + R[lson(u)] + S[lson(u)] * length(rson(u));}void pushdown(int u) {if (T[u]) {maintain(lson(u), T[u]);maintain(rson(u), T[u]);T[u] = 0;}}void build (int u, int l, int r) {lc[u] = l, rc[u] = r;S[u] = L[u] = R[u] = T[u] = 0;if (l == r) return;int mid = (l+r)>>1;build (lson(u), l, mid);build (rson(u), mid+1, r);pushup(u);}void modify(int u, int l, int r, int v) {if (l <= lc[u] && rc[u] <= r) {maintain(u, v);return;}pushdown(u);int mid = (lc[u] + rc[u]) >> 1;if (l <= mid) modify(lson(u), l, r, v);if (r > mid) modify(rson(u), l, r, v);pushup(u);}ll query(int u, int l, int r) {if (l <= lc[u] && rc[u] <= r)return S[u];pushdown(u);int mid = (lc[u] + rc[u]) >> 1;ll ret = 0;if (l <= mid) ret += query(lson(u), l, r);if (r > mid) ret += query(rson(u), l, r);pushup(u);return ret;}ll queryLeft(int u, int l, int r) {if (l <= lc[u] && rc[u] <= r)return L[u] + S[u] * (lc[u] - l);pushdown(u);int mid = (lc[u] + rc[u]) >> 1;ll ret = 0;if (l <= mid) ret += queryLeft(lson(u), l, r);if (r > mid) ret += queryLeft(rson(u), l, r);pushup(u);return ret;}ll queryRight(int u, int l, int r) {if (l <= lc[u] && rc[u] <= r)return R[u] + S[u] * (r - rc[u]);pushdown(u);int mid = (lc[u] + rc[u]) >> 1;ll ret = 0;if (l <= mid) ret += queryRight(lson(u), l, r);if (r > mid) ret += queryRight(rson(u), l, r);pushup(u);return ret;}
}A, D;int N, M;int main () {int cas;scanf("%d", &cas);for (int kcas = 1; kcas <= cas; kcas++) {scanf("%d%d", &N, &M);A.build(1, 2, 2 * N);D.build(1, 1, 2 * N - 1);
//      A.build(1, 1, 2 * N);
//      D.build(1, 1, 2 * N);printf("Case #%d:\n", kcas);int t, l, r, x1, y1, x2, y2;while (M--) {scanf("%d", &t);if (t == 1) {scanf("%d%d", &l, &r);A.modify(1, l, r, 1);} else if (t == 2) {scanf("%d%d", &l, &r);D.modify(1, l + N, r + N, 1);} else {scanf("%d%d%d%d", &x1, &x2, &y1, &y2);ll ans = 0, t = min(x2-x1, y2-y1) + 1;;l = x2 + y1, r = x1 + y2;if (l > r) swap(l, r);ans += A.query(1, l, r) * t;ans += A.queryLeft(1, x1+y1, l-1);ans += A.queryRight(1, r+1, x2+y2);l = x1-y1+N, r = x2-y2+N;if (l > r) swap(l, r);ans += D.query(1, l, r) * t;ans += D.queryLeft(1, x1-y2+N, l-1);ans += D.queryRight(1, r+1, x2-y1+N);printf("%lld\n", ans);}}}return 0;
}

hdu 5454 Excited Database(线段树)相关推荐

  1. HDU 5454 Excited Database 线段树的维护

    传送门:HDU5454 Excited Database Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 65535/102400 K ...

  2. HDU 5454 Excited Database【线段树】

    简单线段树,就是推公式的过程有点不是特别熟练. 按照叉姐的方法,可以用三个树状数组维护,三种情况. 按照坦克工程师的方法,用容斥,将一个矩形分解成三个三角形,一个大的直角三角形减去两个小的直角三角形, ...

  3. HDU 5454 Excited Database (2015年沈阳赛区网络赛E题)

    1.题目描述:点击打开链接 2.解题思路:本题利用线段树解决,根据题意,我们需要建立两棵线段树,分别维护主对角线,副对角线.每个线段树的结点需要维护sum,sumL,sumR,其中,sum表示当前区间 ...

  4. hdu 3397 Sequence operation(线段树,lazy,区间合并)

    hdu 3397 Sequence operation 线段树lazy和区间合并结合的一个题,相当于几个题集中到一起嘛,分开想就好了 0,1,2操作都要lazy,2的异或操作找到每一只含1或只含0的区 ...

  5. 2016 Multi-University Training Contest 10 [HDU 5861] Road (线段树:区间覆盖+单点最大小)...

    HDU 5861 题意 在n个村庄之间存在n-1段路,令某段路开放一天需要交纳wi的费用,但是每段路只能开放一次,一旦关闭将不再开放.现在给你接下来m天内的计划,在第i天,需要对村庄ai到村庄bi的道 ...

  6. hdu 2871 Memory Control(线段树)

    题目链接:hdu 2871 Memory Control 题目大意:模拟一个内存分配机制. Reset:重置,释放全部空间 New x:申请内存为x的空间,输出左地址 Free x:释放地址x所在的内 ...

  7. HDU 4031 Attack(线段树/树状数组区间更新单点查询+暴力)

    Attack Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Others) Total Sub ...

  8. HDU 4262 Juggler (模拟+线段树优化)

    转载请注明出处,谢谢http://blog.csdn.net/acm_cxlove/article/details/7854526       by---cxlove http://acm.hdu.e ...

  9. HDU 5669 Road(线段树建树)(分层图最短路)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5669 [分析]线段树建树+分层图最短路 #include <cstdio> #includ ...

最新文章

  1. Logback 配置文件这样优化,TPS提高 10 倍
  2. Android网络连接异常处理方案
  3. view.ondraw
  4. 关于spark的mllib学习总结(Java版)
  5. MapReduce的简单实例WordCount
  6. 【Spring-AOP-1】AOP相关概念
  7. python常用函数年初大总结
  8. ado 阿里云 mysql_ADO 操作数据库(一)--Ado简介
  9. Go语言实现线程安全访问队列
  10. typedef int Myfunc(const char *,const struct stat *,int)
  11. layui表格边框_layui怎么固定表格的表头
  12. es 链接mysql,用python简单实现mysql数据同步到ElasticSearch的教程
  13. Samba 常用服务器搭建操作过程
  14. VHDL数控分频器及其应用
  15. 利用win10自带的工具测硬盘读写速度
  16. java abs是什么意思_Java abs()方法
  17. Ubuntu 16.04 笔记本双显卡安装 CUDA9.0
  18. 华为吹响“伙伴暨开发者”集结号:共赢数字时代
  19. QTextEdit 控件的妙用(以及与QPlainTextEdit的区别)
  20. 【软件构造】——课程篇 高屋建瓴,从宏观角度谈软件构造

热门文章

  1. vue-cli 原理分析
  2. BootLoader是什么 转载至百度百科
  3. ipv4与ipv6的联系与区别
  4. 数据结构和算法(四)之链表结构
  5. 第六周 day6 python学习笔记
  6. python主函数调用格式_Python入门基础中怎么定义函数,函数调用,函数传递参数...
  7. HTML5+CSS3+JS小实例:仿制网易云音乐网站的轮播图
  8. 局域网如何共享文件?计算机1通过ip访问计算机2,拿取共享文件。
  9. autogen.sh出错
  10. 有关3d引擎优化的一些搜索整理