标签:logs 树状 scan struct bit root 对比 open inline
★★ 输入文件:counttree.in
输出文件:counttree.out
简单对比
时间限制:1 s 内存限制:128 MB
输入第一行包含一个整数N,以下N行每行包含一个整数,其中第i行的整数表示编号为i的节点的父亲节点的编号,根的父亲节点编号为0。
输出包含N行,其中第i行给出编号为i的节点的统计结果。
3 2 3 0
0 1 2
在此键入。
20%的数据1<=n<=1000
100%的数据1<=n<=100000
树状数组
#include <cstdio> #define N 100005 struct Edge { int next,to; }edge[N]; int ans[N],root,tag[N],n,fa[N],head[N],cnt; inline int lowbit(int x) {return x&(-x);} inline int query(int x) { int ans=0; for(;x;x-=lowbit(x)) ans+=tag[x]; return ans; } inline void modify(int x) { for(;x<=n;x+=lowbit(x)) tag[x]++; } void dfs(int x) { ans[x]=-query(x-1); modify(x); for(int i=head[x];i;i=edge[i].next) { int v=edge[i].to; if(v!=fa[x]) dfs(v); } ans[x]+=query(x-1); } int main() { freopen("counttree.in","r",stdin);freopen("counttree.out","w",stdout); scanf("%d",&n); for(int i=1;i<=n;++i) { scanf("%d",&fa[i]); if(!fa[i]) root=i; else { edge[++cnt].next=head[fa[i]]; edge[cnt].to=i; head[fa[i]]=cnt; } } dfs(root); for(int i=1;i<=n;++i) printf("%d ",ans[i]); return 0; }
标签:logs 树状 scan struct bit root 对比 open inline
原文地址:http://www.cnblogs.com/ruojisun/p/7413764.html