2039. 树的统计

★★   输入文件:counttree.in   输出文件:counttree.out   简单对比
时间限制:1 s   内存限制:128 MB

【题目描述】

关于树的统计问题有多种多样的版本,这里你需要解决一个比较简单的问题:对于一棵包含N个节点的有根树,将所有点从1到N编号后,对于每一个节点v,统计出以v为根的子树中有多少个点的编号比v小。

【输入格式】

输入第一行包含一个整数N,以下N行每行包含一个整数,其中第i行的整数表示编号为i的节点的父亲节点的编号,根的父亲节点编号为0。

【输出格式】

输出包含N行,其中第i行给出编号为i的节点的统计结果。

【样例输入】

3

2

3

0

【样例输出】

0 1 2

【提示】

在此键入。

【来源】

20%的数据1<=n<=1000

100%的数据1<=n<=100000

思路:

  就是用搜索w

T代码:

#include <algorithm>
#include <iostream>
#include <cstring>
#include <queue>
#include <string>
#include <cstdio> using namespace std; inline int reads()
{
int x=,f=;
char ch=getchar(); while(ch>'' || ch<'')
{
if(ch=='-') f=-;
ch=getchar();
} while(ch>='' && ch<='')
{
x=x*+ch-'';
ch=getchar();
} return x*f;
} const int Ms = 1e5 + ;
int n,root;
int dad[Ms];
bool Vss[Ms];
int sum[Ms];
int deep[Ms];
int h[Ms],num;
queue<int>q; struct AC{
int to,next;
}t[Ms]; void ADD(int x,int y)
{
t[++num].to=y;
t[num].next=h[x];
h[x]=num;
} int ans; void dfs(int u)
{ ///dfs the deep
Vss[u]=true;
int maxx=;
for(int j=h[u];j;j=t[j].next)
{
int v=t[j].to;
if(Vss[v]) continue;
deep[v]=deep[u]+; ///update
dad[v]=u; ///u is v's dad
dfs(v); ///continue dfs
if(sum[v] > sum[maxx]) maxx=v; ///update
sum[u]+=sum[v]+;
}
} void QwQ(int now)
{
ans=;
int nowdeep=deep[now];
for(int i=;i<now;i++)
{
// if(i==now) continue;
if(ans>=sum[now]) break;
if(deep[i]>nowdeep && ans<=sum[now])
{
if(dad[i]==now) ans++;
else
{
int j=dad[i];
while(deep[j] > deep[now])
{
j=dad[j];
if(j==now) ans++;
}
}
}
}
} int main()
{
freopen("counttree.in","r",stdin);
freopen("counttree.out","w",stdout);
n=reads();
int i=; ///fu chu zhi !!!
int QAQ;
int sss=n;
while(sss--)
{
///i's dad is dad[i]
QAQ=reads();
ADD(QAQ,i);
///find the root
if(QAQ==) root=i;
i++;
}
deep[root]=;
sum[]=-;
dfs(root);
for(int i=;i<=n;i++)
{
QwQ(i);
printf("%d\n",ans);
}
return ;
}

QAQ

A代码:

#include <algorithm>
#include <iostream>
#include <cstring>
#include <queue>
#include <string>
#include <cstdio> using namespace std; inline int reads()
{
int x=,f=;
char ch=getchar(); while(ch>'' || ch<'')
{
if(ch=='-') f=-;
ch=getchar();
} while(ch>='' && ch<='')
{
x=x*+ch-'';
ch=getchar();
} return x*f;
} const int Ms = 1e5 + ;
int n,root;
int now;
int h[Ms],num; struct AC{
int to,next;
}t[Ms]; void ADD(int x,int y)
{
t[++num].to=y;
t[num].next=h[x];
h[x]=num;
} int ans; void dfs(int u)
{
for(int j=h[u];j;j=t[j].next)
{
if(j<now) ++ans;
dfs(j); ///continue dfs
}
} int main()
{
freopen("counttree.in","r",stdin);
freopen("counttree.out","w",stdout);
n=reads();
int QAQ,sss=n,i=;
while(sss--)
{
///i's dad is dad[i]
QAQ=reads();
ADD(QAQ,i);
i++;
}
for(int i=;i<=n;++i)
{
now=i;
ans=;
dfs(i);
printf("%d\n",ans);
}
return ;
}

23333

cogs2039树的统计 x的更多相关文章

  1. BZOJ 1036: [ZJOI2008]树的统计Count [树链剖分]【学习笔记】

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 14302  Solved: 5779[Submit ...

  2. bzoj1036 [ZJOI2008]树的统计Count

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 12646  Solved: 5085 [Subm ...

  3. BZOJ 1036: [ZJOI2008]树的统计Count

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 14354  Solved: 5802 [Subm ...

  4. 【BZOJ1036】[ZJOI2008]树的统计Count 树链剖分

    [BZOJ1036][ZJOI2008]树的统计Count Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. ...

  5. BZOJ-1036 树的统计Count 链剖线段树(模板)=(树链剖分+线段树)

    潇爷昨天刚刚讲完...感觉得还可以...对着模板打了个模板...还是不喜欢用指针.... 1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Lim ...

  6. C++之路进阶——codevs2460(树的统计)

    2460 树的统计 2008年省队选拔赛浙江  时间限制: 2 s  空间限制: 128000 KB  题目等级 : 大师 Master       题目描述 Description 一棵树上有n个节 ...

  7. BZOJ 1036 树的统计-树链剖分

    [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 12904 Solved: 5191[Submit][Status ...

  8. BZOJ_1036_[ZJOI2008]_树的统计Conut_(树链剖分)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1036 给出一棵树以及各点的权值,对数进行如下三种操作: 1.改变某一节点u的值为t; 2.求节 ...

  9. bzoj 1036 [ZJOI2008]树的统计Count(树链剖分,线段树)

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 10677  Solved: 4313[Submit ...

随机推荐

  1. [转帖]运行时库(runtime library)

    运行时库(runtime library) https://blog.csdn.net/xitie8523/article/details/82712105 没学过这些东西 或者当时上课没听 又或者 ...

  2. python简单验证码识别

    在学习python通过接口自动登录网站时,用户名密码.cookies.headers都好解决但是在碰到验证码这个时就有点棘手了:于是通过网上看贴,看官网完成了对简单验证码的识别,如果是复杂的请看大神的 ...

  3. CF39H 【Multiplication Table】

    这题可以枚举出每个i,j 位置的数>需要用到进制转换 int zh(int x){ long long sum=0,i=0; while(x){ sum=sum+((x%n)*pow(10,i) ...

  4. C++运算符重载总结(真的很详细了w(゚Д゚)w)

    C++运算符重载总结(真的很详细了w(゚Д゚)w) 概述 运算符重载可以使得一些特殊类型参与运算,我是这样理解的. 使用友元形式的运算符重载 //一般形式 class x{ friend 返回类型 o ...

  5. file_put_contents实现内容追加

    file_put_contents("test.txt", "This is another something.", FILE_APPEND); FILE_A ...

  6. python_0基础开始_day13

    第十三节 一,匿名函数 匿名函数 == 一行函数 lambda == def == 关键字 函数体中存放的是代码 生成器体中存放的也是代码 就是yield导致函数和生成器的结果不统一 lambda x ...

  7. multivariate_normal 多元正态分布

    多元正态分布 正态分布大家都非常熟悉了,多元正态分布就是多维数据的正态分布,其概率密度函数为 上式为 x 服从 k 元正态分布,x 为 k 维向量:|Σ| 代表协方差矩阵的行列式 二维正态分布概率密度 ...

  8. js数据结构-链表

    链表和数组 大家都用过js中的数组,数组其实是一种线性表的顺序存储结构,它的特点是用一组地址连续的存储单元依次存储数据元素.而它的缺点也正是其特点而造成,比如对数组做删除或者插入的时候,可能需要移动大 ...

  9. js小数和百分数的转换

    一.百分数转化为小数 function toPoint(percent){ var str=percent.replace("%",""); str= str/ ...

  10. webpack的基本使用

    安装webpack npm i webpack -g npm i webpack-cli -g 1.基础用法(无需配置webpack.config.js文件) 1.2 新建需要打包的测试文件input ...