二维树状数组(水题) POJ1195
前段时间遇到线段树过不了,树状数组却过了的题。(其实线段树过得了的)
回忆了下树状数组。
主要原理,还是二进制位数,每一项的和表示其为它的前((最后一位1及其后)的二进制数)和,可从二进制图来看。(用线段树想一想其实只是线段树编号不同而已,本质类似)
写了下二维树状数组,几乎和一维相同,也没必要不同。
#include <cstdio>
#include <cstring> int l,r,x,y,n,a,p,sum[][]; inline int lowbit(int x)
{
return x&(-x);
} void update(int x, int y, int p)
{
for(int i=x; i<=n; i+=lowbit(i))
for(int j=y; j<=n; j+=lowbit(j))
sum[i][j]+=p;
} int query(int x, int y)
{
int ret=;
for(int i=x; i>; i-=lowbit(i))
for(int j=y; j>; j-=lowbit(j))
ret+=sum[i][j];
return ret;
} int main()
{
while(scanf("%d",&p)!=EOF)
{
if(p==) break;
switch (p) {
case :
memset(sum,,sizeof(sum));
scanf("%d",&n);
break;
case :
scanf("%d%d%d",&x,&y,&a);
update(x+,y+,a);
break;
case :
scanf("%d%d%d%d",&x,&y,&l,&r);
printf("%d\n",query(l+,r+)-query(l+,y)-query(x,r+)+query(x,y));
break;
}
}
return ;
}
二维树状数组(水题) POJ1195的更多相关文章
- hiho 172周 - 二维树状数组模板题
		
题目链接 描述 You are given an N × N matrix. At the beginning every element is 0. Write a program supporti ...
 - 【bzoj1452】[JSOI2009]Count  二维树状数组
		
题目描述 输入 输出 样例输入 样例输出 1 2 题解 二维树状数组 一开始没看到 1≤c≤100 ,想到了主X树和X块,结果发现c的范围那么小... 二维树状数组水题,和一维的一样,向上修改,向下查 ...
 - POJ 2029 Get Many Persimmon Trees (模板题)【二维树状数组】
		
<题目链接> 题目大意: 给你一个H*W的矩阵,再告诉你有n个坐标有点,问你一个w*h的小矩阵最多能够包括多少个点. 解题分析:二维树状数组模板题. #include <cstdio ...
 - 二维树状数组总结&&【洛谷P4514】 上帝造题的七分钟
		
P4514 上帝造题的七分钟 题目描述 "第一分钟,X说,要有矩阵,于是便有了一个里面写满了00的n×mn×m矩阵. 第二分钟,L说,要能修改,于是便有了将左上角为(a,b)(a,b),右下 ...
 - POJ1195(二维树状数组)
		
Mobile phones Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 17176 Accepted: 7920 De ...
 - POJ 1195 Mobile phones【二维树状数组】
		
<题目链接> 题目大意: 一个由数字构成的大矩阵,开始是全0,能进行两种操作1) 对矩阵里的某个数加上一个整数(可正可负)2) 查询某个子矩阵里所有数字的和要求对每次查询,输出结果 解题分 ...
 - 模板:二维树状数组 【洛谷P4054】 [JSOI2009]计数问题
		
P4054 [JSOI2009]计数问题 题目描述 一个n*m的方格,初始时每个格子有一个整数权值.接下来每次有2种操作: 改变一个格子的权值: 求一个子矩阵中某种特定权值出现的个数. 输入输出格式 ...
 - hdu 2642 二维树状数组 单点更新区间查询 模板水题
		
Stars Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/65536 K (Java/Others) Total Subm ...
 - tyvj P1716 - 上帝造题的七分钟 二维树状数组区间查询及修改 二维线段树
		
P1716 - 上帝造题的七分钟 From Riatre Normal (OI)总时限:50s 内存限制:128MB 代码长度限制:64KB 背景 Background 裸体就意味着 ...
 
随机推荐
- 图片轮播插件-carouFredSel
			
carouFredSel图片轮播插件基于Jquery,比较常规的轮播插件,支持滚轮及键盘左右按键,加入其它插件可实现更加复杂的特效. 主页地址:http://caroufredsel.dev7stud ...
 - pure.css
			
注释中address是纠正的意思 等价于correct/*! Pure v0.5.0 Copyright 2014 Yahoo! Inc. All rights reserved. Licensed ...
 - 1293: [SCOI2009]生日礼物 - BZOJ
			
Description 小西有一条很长的彩带,彩带上挂着各式各样的彩珠.已知彩珠有N个,分为K种.简单的说,可以将彩带考虑为x轴,每一个彩珠有一个对应的坐标(即位置).某些坐标上可以没有彩珠,但多个彩 ...
 - 【BZOJ】【2132】圈地计划
			
网络流/最小割 Orz Hzwer 这类大概是最小割建模中的经典应用吧…… 黑白染色,然后反转黑色的技巧感觉很巧妙!这个转化太神奇了…… /****************************** ...
 - iOS 沙盒购买,弹出“需要验证”,“继续登录”的问题?
			
点击购买后,能弹出 确认购买的对话框, 您想以xxx的价格买一个xxx吗? [environment:sandbox] 点击确认购买后,弹出"需要验证" 点击继续,输入密码后.竟然 ...
 - JavaScript执行上下文
			
变量声明.函数声明为何会提升?js执行时是如何查找变量的?JavaScript中最基本的部分——执行上下文(execution context) 什么是执行上下文? 当JavaScript代码运行,执 ...
 - dynamic介绍
			
Visual C# 2010 引入了一个新类型 dynamic. 该类型是一种静态类型,但类型为 dynamic 的对象会跳过静态类型检查. 大多数情况下,该对象就像具有类型 object 一样. 在 ...
 - jquery控制按钮的禁用与启用
			
jquery禁用a标签方法1: $(document).ready(function () { $("a").each(function () { var textValue = ...
 - zend studio 10破解/汉化(转发)
			
转发:http://blog.csdn.net/qq1355541448/article/details/16807429 Zend Studio 10正式版破解及汉化 2013年03月12日 ⁄ P ...
 - java 写文本文件
			
code 1:将特定String写入特定文件,不覆盖. import java.io.*; import java.util.*; public class OutputLog { public st ...