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. Keras模型训练的断点续训、早停、效果可视化

    训练:model.fit()函数 fit(x=None, y=None, batch_size=None, epochs=, verbose=, callbacks=None, validation_ ...

  2. Wannafly挑战赛19:C. 多彩的树

    传送门 $k$的范围非常小, $O(n2^k)$求出状态最多为$S$的路径数, 然后容斥. #include <iostream> #include <sstream> #in ...

  3. Mysql主从分离介绍及实现

    参考: http://www.cnblogs.com/panxuejun/p/5887118.html https://www.cnblogs.com/alvin_xp/p/4162249.html ...

  4. spring boot @Value源码解析

    Spring boot 的@Value只能用于bean中,在bean的实例化时,会给@Value的属性赋值:如下面的例子: @SpringBootApplication @Slf4j public c ...

  5. C# 面向对象6 之前的复习

    复习练习 THIS:调用当前类的构造函数

  6. 爬取YY评级信息

    #!/usr/bin/env python # -*- coding: utf-8 -*- # @File : 爬取YY评级基本信息.py # @Author: lattesea # @Date : ...

  7. oracle数据库连接问题org.springframework.jdbc.support.MetaDataAccessException: JDBC DatabaseMetaData method not implemented by JDBC driver - upgrade your driver...

    org.springframework.jdbc.support.MetaDataAccessException: JDBC DatabaseMetaData method not implement ...

  8. c++ 初学者的画图库EasyX

    EasyX 什么是easyx? EasyX 是针对 C++ 的图形库,可以帮助 C++语言初学者快速上手图形和游戏编程.其实就是c++的一个图形库让初学者不用只在控制台输出代码,而是在图形界面进行开发 ...

  9. 常见shell用法

    分析nginx访问日志 awk '{a[b[$1]++]}END{for(i=length(a);i>0;i--)for(j in b)if(b[j]==i){c++;if(c<=10)p ...

  10. spark源码本地调试

    1.前提条件: 1)安装jdk 版本: 2)安装scala 版本: 3)安装sbt 版本: 4)安装maven 5)安装git 版本: 6)安装idea,并配置好sbt.git.maven 2.从gi ...