codevs 1080 线段树练习
链接:http://codevs.cn/problem/1080/
先用树状数组水一发,再用线段树水一发
树状数组代码:84ms
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<math.h>
#include<string.h>
#include<vector>
#include<queue>
#include<iterator>
#include<vector>
#include<set>
#define dinf 0x3f3f3f3f
typedef long long ll;
const int Max=(<<)+;
using namespace std; #define SIZE 1000005 int c[SIZE],a[SIZE]; int Lowbit(int x)
{
return x&(-x);
} int Sum(int x)
{
int sum=;
while(x>)
{
sum+=c[x];
x-=Lowbit(x);
}
return sum;
} void Update(int i,int x)
{
while(i<=SIZE)//要把所有的与i相关的c数组中的值全部更新,不然会出错
{
c[i]+=x;
i+=Lowbit(i);
}
} int main()
{
int n,m;
while(~scanf("%d",&n))
{
memset(a,,sizeof(a));
memset(c,,sizeof(c)); for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
Update(i,a[i]);
}
scanf("%d",&m);
int op,node,num;
for(int i=;i<=m;i++)
{
scanf("%d %d %d",&op,&node,&num);
if(op==)
Update(node,num);
else if(op==)
{
printf("%d\n",Sum(num)-Sum(node-));
}
}
}
return ;
}
线段树代码:48ms
#include<cstdio>
using namespace std;
struct RE
{
int sum,l,r;
}tree[];
int a[];
void build(int node,int l,int r)
{
int mid=(l+r)>>;
tree[node].l=l;
tree[node].r=r;
if (l==r)
{
tree[node].sum=a[l];
return;
}
build(*node,l,mid);
build(*node+,mid+,r);
tree[node].sum+=tree[*node].sum+tree[*node+].sum;
}
void updata(int node,int a,int b)
{
int mid=(tree[node].l+tree[node].r)>>;
if (mid==tree[node].l&&mid==tree[node].r)
{
tree[node].sum+=b;
return;
}
if (a<=mid)
updata(*node,a,b);
else
updata(*node+,a,b);
tree[node].sum+=b;
}
int query(int node,int l,int r)
{
int mid=(tree[node].l+tree[node].r)>>;
if (tree[node].l==l&&tree[node].r==r)
return tree[node].sum;
if (l>mid)
return query(*node+,l,r);
if (r<=mid)
return query(*node,l,r);
return query(*node,l,mid)+query(*node+,mid+,r);
}
int main()
{
int n,m;
scanf("%d",&n);
int i,j;
for (i=;i<=n;i++)
scanf("%d",&a[i]);
build(,,n);
scanf("%d",&m);
int sign,a,b;
for (i=;i<=m;i++)
{
scanf("%d%d%d",&sign,&a,&b);
if (sign==) updata(,a,b);
else printf("%d\n",query(,a,b));
}
return ;
}
codevs 1080 线段树练习的更多相关文章
- codevs 1080 线段树点修改
先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...
- codevs 1080 线段树练习 CDQ分治
codevs 1080 线段树练习 http://codevs.cn/problem/1080/ 时间限制: 1 s 空间限制: 128000 KB 题目描述 Description 一行N个 ...
- codevs 1080 线段树练习--用树状数组做的
1080 线段树练习 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 一行N个方格,开始每个格子里都有一个整数.现在动态 ...
- Codevs 1080 线段树练习(CDQ分治)
1080 线段树练习 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 一行N个方格,开始每个格子里都有 ...
- codevs——1080 线段树练习
1080 线段树练习 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 一行N个方格,开始每个格子里都有 ...
- Codevs 1080 线段树联系
题目描述 Description 一行N个方格,开始每个格子里都有一个整数.现在动态地提出一些问题和修改:提问的形式是求某一个特定的子区间[a,b]中所有元素的和:修改的规则是指定某一个格子x,加上或 ...
- codevs 1080 线段树练习(线段树)
题目: 题目描述 Description 一行N个方格,开始每个格子里都有一个整数.现在动态地提出一些问题和修改:提问的形式是求某一个特定的子区间[a,b]中所有元素的和:修改的规则是指定某一个格子x ...
- codevs 1082 线段树练习 3(区间维护)
codevs 1082 线段树练习 3 时间限制: 3 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...
- codevs 1082 线段树区间求和
codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...
随机推荐
- LazyLoad.js及scrollLoading.js
http://blog.csdn.net/ning109314/article/details/7042829 目前图片延迟加载主要分两大块,一是触发加载(根据滚动条位置加载图片):二是自动预加载(加 ...
- iOS开发——UI进阶篇(七)程序启动原理、打电话、发短信
一.Info.plist常见的设置 1.建立一个工程后,会在Supporting files文件夹下看到一个“工程名-Info.plist”的文件,该文件对工程做一些运行期的配置,非常重要,不能删除 ...
- jquery版时钟(css3实现)
做时钟的主要原因是因为喜欢,觉得它好看(本人对特效有点爱不释手……).做的时候感觉工程量会有点大,做着做着发现实现起来其实并不难,只要理清思绪,其实还蛮简单的(我制作东西喜欢整体方向制定好,然后边做边 ...
- 教你搭建SpringSecurity3框架( 更新中、附源码)
源码下载地址:http://pan.baidu.com/s/1qWsgIg0 一.web.xml <?xml version="1.0" encoding="UTF ...
- Hello 2016
Hello 2016 I am really happy to work and study here. Nothing is better than be oneself ! It's import ...
- BestCoder Round #61 1002 Game
Problem Description XY is playing a game:there are N pillar in a row,which numbered from 1 to n.Each ...
- poj3984
定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, ...
- linux 终端全局代理设置
http://www.webupd8.org/2010/10/how-to-set-proxy-for-terminal-quick.html 即 export http_proxy='http:// ...
- VNC server grey screen under ubuntu 14.04
nstall these packages: apt-get install gnome-panel gnome-settings-daemon metacity nautilus gnome-ter ...
- 常见的SQL语句
1.select decode(a.xh,'','0','1')||decode(b.xh,'','0','1') from A a left join B b on a.xh=b.xh where ...