poj 3321(带时间戳 + 区间统计)
题目描述:
给定一颗树,求某个节点的子树的val值之和
可以用树的前序遍历给每一个节点编号,从而可以确定一个节点的子树的范围,这样就可以进行直接在区间上进行统计了。
vector < int > Map[maxN]写成typedef vector <int> INT; vector <INT> Map(maxN);就不超时了。
线段树
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
#include <vector>
#define LL long long
using namespace std;
//线段树
//区间每点增值,求区间和
const int maxN = ;
struct node
{
int lt, rt;
int val;
}tree[*maxN]; //向上更新
void pushUp(int id)
{
tree[id].val = tree[id<<].val + tree[id<<|].val;
} //建立线段树
void build(int lt, int rt, int id)
{
tree[id].lt = lt;
tree[id].rt = rt;
// tree[id].val = 1;//每段的初值,根据题目要求
if (lt == rt)
{
tree[id].val=;
return;
}
int mid = (lt+rt)>>;
build(lt, mid, id<<);
build(mid+, rt, id<<|);
pushUp(id);
} //增加区间内每个点固定的值
void add(int lt, int rt, int id)
{
if (lt <= tree[id].lt && rt >= tree[id].rt)
{
if(tree[id].val==)
tree[id].val=;
else
tree[id].val=;
return;
}
int mid = (tree[id].lt+tree[id].rt)>>;
if (lt <= mid)
add(lt, rt, id<<);
if (rt > mid)
add(lt, rt, id<<|);
pushUp(id);
} //查询某段区间内的和
int query(int lt, int rt, int id)
{
if (lt <= tree[id].lt && rt >= tree[id].rt)
return tree[id].val;
int mid = (tree[id].lt+tree[id].rt)>>;
int ans = ;
if (lt <= mid)
ans += query(lt, rt, id<<);
if (rt > mid)
ans += query(lt, rt, id<<|);
return ans;
} struct NODE
{
int cnt,l,r;
}a[maxN];
typedef vector<int > INT;
vector<INT > Map(maxN);
int vis[maxN];
int number;
void dfs(int fa)
{
for(int i=;i<Map[fa].size();i++)
{
int son=Map[fa][i];
if(vis[son]==)
{
a[son].cnt=++number;
a[son].l= number;
vis[son]=;
dfs(son);
a[son].r=number;
}
}
}
void init()
{
for(int i=;i<maxN;i++)
Map[i].clear();
}
int main()
{
// freopen("test.txt","r",stdin);
int n,m;
while(~scanf("%d",&n))
{
init();
for(int i=;i<=n-;i++)
{
int from,to;
scanf("%d%d",&from,&to);
Map[from].push_back(to);
Map[to].push_back(from);
}
number=;
memset(vis,,sizeof(vis));
a[].cnt=;
a[].l=;
vis[]=; dfs(); a[].r=number; build(a[].l,a[].r,);
//for(int i=1;i<=9;i++)
// printf("%d %d %d\n",a[i].cnt,a[i].l,a[i].r);
int M;
scanf("%d",&M);
char str[]; int id;
while(M--)
{
scanf("%s%d",str,&id);
//printf("%s\n",str);
if(str[]=='Q')
{
printf("%d\n",query(a[id].l,a[id].r,) );
}
if(str[]=='C')
{
add(a[id].cnt,a[id].cnt,);
}
}
}
return ;
}
树状数组
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
#include <vector>
#define LL long long
using namespace std;
const int maxN = ;
int n;
//树状数组
int C[maxN],A[maxN];
int lowbit(int x)
{
return x&(-x);
}
int sum(int x)
{
int ret=;
while(x>)
{
ret+=C[x]; x-=lowbit(x);
}
return ret;
}
void update(int x,int pls)
{
int d;
if(pls==)
{
if(A[x]==)
d=;
if(A[x]==)
d=-;
}
else
d=;
A[x]+=d;
while(x<=n)
{
C[x]+=d; x+=lowbit(x);
}
}
struct NODE
{
int cnt,l,r;
}a[maxN];
typedef vector<int> INT;
vector < INT > Map(maxN);
int vis[maxN];
int number;
void dfs(int fa)
{
for(int i=;i<Map[fa].size();i++)
{
int son=Map[fa][i];
if(vis[son]==)
{
a[son].cnt=++number;
a[son].l= number;
vis[son]=;
dfs(son);
a[son].r=number;
}
}
}
void init()
{
for(int i=;i<maxN;i++)
Map[i].clear();
}
int main()
{
//freopen("test.txt","r",stdin);
while(~scanf("%d",&n))
{
init();
for(int i=;i<=n-;i++)
{
int from,to;
scanf("%d%d",&from,&to);
Map[from].push_back(to);
Map[to].push_back(from);
}
number=;
memset(vis,,sizeof(vis));
a[].cnt=;
a[].l=;
vis[]=; dfs(); a[].r=number;
memset(C,,sizeof(C));
memset(A,,sizeof(A));
for(int i=;i<=n;i++)
update(i,);
int M;
scanf("%d",&M);
char str[]; int id;
while(M--)
{
scanf("%s%d",str,&id);
if(str[]=='Q')
{
printf("%d\n",sum(a[id].r) -sum(a[id].l-) );
}
if(str[]=='C')
{
update(a[id].cnt,);
}
}
}
return ;
}
poj 3321(带时间戳 + 区间统计)的更多相关文章
- poj 3321 单点更新 区间求和
Apple Tree Time Limit: 2000 MS Memory Limit: 65536 KB 64-bit integer IO format: %I64d , %I64u Java c ...
- POJ.3321 Apple Tree ( DFS序 线段树 单点更新 区间求和)
POJ.3321 Apple Tree ( DFS序 线段树 单点更新 区间求和) 题意分析 卡卡屋前有一株苹果树,每年秋天,树上长了许多苹果.卡卡很喜欢苹果.树上有N个节点,卡卡给他们编号1到N,根 ...
- Hdu 3887 Counting Offspring \ Poj 3321 Apple Tree \BZOJ 1103 [POI2007]大都市meg
这几个题练习DFS序的一些应用. 问题引入: 给定一颗n(n <= 10^5)个节点的有根树,每个节点标有权值,现有如下两种操作: 1.C x y 以节点x的权值修改为y. 2.Q x ...
- hdu 1540 Tunnel Warfare(线段树区间统计)
Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) T ...
- POJ 3321:Apple Tree + HDU 3887:Counting Offspring(DFS序+树状数组)
http://poj.org/problem?id=3321 http://acm.hdu.edu.cn/showproblem.php?pid=3887 POJ 3321: 题意:给出一棵根节点为1 ...
- poj 3321 Apple Trie
/* poj 3321 Apple Trie 这道题的关键是如何将一个树建成一个一维数组利用树状数组来解题! 可以利用dfs()来搞定,我们在对一个节点深搜后,所经过的节点的数目就是该节点的子树的数目 ...
- POJ 3321 Apple Tree(DFS序+线段树单点修改区间查询)
Apple Tree Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 25904 Accepted: 7682 Descr ...
- bzoj 3065: 带插入区间K小值 替罪羊树 && AC300
3065: 带插入区间K小值 Time Limit: 60 Sec Memory Limit: 512 MBSubmit: 1062 Solved: 253[Submit][Status] Des ...
- 洛谷P2879 [USACO07JAN]区间统计Tallest Cow
To 洛谷.2879 区间统计 题目描述 FJ's N (1 ≤ N ≤ 10,000) cows conveniently indexed 1..N are standing in a line. ...
随机推荐
- 洛谷P1504 积木城堡
题目描述 XC的儿子小XC最喜欢玩的游戏用积木垒漂亮的城堡.城堡是用一些立方体的积木垒成的,城堡的每一层是一块积木.小XC是一个比他爸爸XC还聪明的孩子,他发现垒城堡的时候,如果下面的积木比上面的积木 ...
- 洛谷P1432 倒水问题
题目背景 In the movie "Die Hard 3", Bruce Willis and Samuel L. Jackson were confronted with th ...
- ubuntu使用git时,终端不显示git分支。
1:问题描述: 在Windows环境下习惯使用git bash操作git分支,最近学习linux环境,发现linux环境终端不显示git分支,相关现象如下: 期望效果是: 我的linux环境 ...
- mybatis使用步骤
1.创建config.xml文件.设置环境.数据源等: 2.设置mapper.xml文件.写sql:下面图中的resultType属性经常会替换为resultMap,不过需要加入<resultM ...
- ORACLE备份、恢复、常用查询
--第一,启动服务,(如果数据库处于启动状态,那么略过这一步) 打开命令行执行以下语句 net start OracleServiceORCL net start OracleOraDb10g_ ...
- 【BZOJ2038】小Z的袜子(莫队)
题意: 给定n个数a1, a2…… an与m个询问(L,R).对于每个询问,从aL, aL+1…… aR这R-L+1个数中随机取出两个数,求这两个数相同的概率. 数据范围:1<=n,m,ai&l ...
- codechef FUN WITH TREES
题目大意: 给一棵树root=1的树: 给一些操作:u v 的路径所有节点的node + val: 最后m个询问:u 节点(包括u) sum%mod 是多少. LCA + RMQ: 我们每次mark ...
- POJ 1860【求解是否存在权值为正的环 屌丝做的第一道权值需要计算的题 想喊一声SPFA万岁】
题意: 有n种钱币,m个钱币兑换点,小明一开始有第n种钱币数量为w. 每个兑换点可以将两种不同的钱币相互兑换,但是兑换前要先收取一定的费用,然后按照比例兑换. 问小明是否可以经过一系列的兑换之后能够将 ...
- ThoughtWorks技术雷达
ThoughtWorks技术雷达 技术成熟方案的一个推荐网站.
- uva 10069 Distinct Subsequences 【dp+大数】
题目:uva 10069 Distinct Subsequences 题意:给出一个子串 x 和母串 s .求子串在母串中的不同序列的个数? 分析:定义dp[i][j]:x 的前 i 个字母在 s 的 ...