hdu1556(树状数组/线段树,区间修改,点查询)
来源:互联网 发布:我是皇玉玺进阶数据 编辑:程序博客网 时间:2024/05/16 18:43
题目链接:点击打开链接
//题目大意:一段序列,给连续的一段涂色,问某个点被涂的次数#include <iostream>#include <algorithm>#include <fstream>#include <sstream>#include <iomanip>#include <cstdio>#include <vector>#include <cstring>#include <cmath>#include <queue>#include <stack>#include <set>#include <map>#define N 100010using namespace std;int sum[N<< 2], add[N<< 2];int a[N], n, x, y;void pushup(int k) { sum[k]= sum[k<< 1]+ sum[k<< 1| 1]; }void build(int l, int r, int k){ if(l== r) { sum[k]= a[l]; return; } int m= (l+ r)>> 1; build(l, m, k<< 1); build(m+ 1, r, k<< 1| 1); pushup(k);}void pushdown(int k, int ln, int rn){ if(add[k]) { add[k<< 1]+= add[k]; add[k<< 1| 1]+= add[k]; sum[k<< 1]+= add[k]* ln; sum[k<< 1| 1]+= add[k]* rn; add[k]= 0; }}void update(int l, int r, int c, int ll, int rr, int k){ if(l<= ll && r>= rr) { sum[k]+= c* (rr- ll+ 1); add[k]+= c; return; } int m= (ll+ rr)>> 1; pushdown(k, m- ll+ 1, rr- m); if(l<= m) update(l, r, c, ll, m, k<< 1); if(r> m) update(l, r, c, m+ 1, rr, k<< 1| 1); pushup(k);}int query(int l, int r, int ll, int rr, int k){ if(l<= ll && r>= rr) return sum[k]; int m= (ll+ rr)>> 1; pushdown(k, m- ll+ 1, rr- m); int ans= 0; if(l<= m) ans+= query(l, r, ll, m, k<< 1); if(r> m) ans+= query(l, r, m+ 1, rr, k<< 1| 1); return ans;}int main(){ while(scanf("%d", &n)== 1 && n) { memset(sum, 0, sizeof(sum)); memset(add, 0, sizeof(add)); memset(a, 0, sizeof(a)); build(1, n, 1); for(int i= 0; i< n; i++) { scanf("%d%d", &x, &y); update(x, y, 1, 1, n, 1); } for(int i= 1; i< n; i++) printf("%d ", query(i, i, 1, n, 1)); printf("%d\n", query(n, n, 1, n, 1)); } return 0;}
阅读全文
0 0
- hdu1556(树状数组/线段树,区间修改,点查询)
- hdu1556 树状数组 区间修改,点查询
- HDU1556 树状数组,线段树区间更新两种方法(主要树状数组)
- hdu1556 Color the ball【树状数组 || 线段树 || 技巧*区间修改】
- hdu1556 color the ball 树状数组区间更新单点查询(附线段树做法)与二维扩展
- 【洛谷】线段树 树状数组区间修改区间查询
- hdu1556 线段树 区间修改
- 模板(线段树 + 树状数组 + 区间修改 + 区间查询)eg:POJ 3468
- 【树状数组】区间修改&点查询
- 【树状数组】点修改&区间查询
- HDU 4031 Attack(树状数组修改区间查询点)
- poj2155(树状数组,区间修改,点查询)
- hdu3584(三维树状数组,区间修改,点查询)
- HDOJ-1556(线段树||树状数组,区间更新+点查询)
- hdu1556 Color the ball(线段树区间修改)
- HDU1556:Color the ball(线段树区间更新单点求值)&&树状数组解法
- 【code[vs]】1082 线段树练习 3 树状数组区间修改、区间查询
- hdu1556树状数组更新区间
- 图片错位
- centos7.2下搭建pptp vpn完整步骤及问题解决方案
- Mybatis配置文件设置自动映射
- python对八大常见排序算法的总结和实现以及时间消耗分析
- 微信小程序demo(新闻类)
- hdu1556(树状数组/线段树,区间修改,点查询)
- python的内存管理机制
- SpringBoot 的学习整理
- css代码实时预览(脑洞大开的操作)
- POJ-1456-Supermarket [贪心]
- 《剑指offer》非递归法判定二叉树是否是对称的
- Java对象转为json
- 剑指offer面试题[41]-和为s的两个数VS和为s的连续正数序列
- CodeForces