cogs2039树的统计 x
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的更多相关文章
- BZOJ 1036: [ZJOI2008]树的统计Count [树链剖分]【学习笔记】
1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 14302 Solved: 5779[Submit ...
- bzoj1036 [ZJOI2008]树的统计Count
1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MB Submit: 12646 Solved: 5085 [Subm ...
- BZOJ 1036: [ZJOI2008]树的统计Count
1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MB Submit: 14354 Solved: 5802 [Subm ...
- 【BZOJ1036】[ZJOI2008]树的统计Count 树链剖分
[BZOJ1036][ZJOI2008]树的统计Count Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. ...
- BZOJ-1036 树的统计Count 链剖线段树(模板)=(树链剖分+线段树)
潇爷昨天刚刚讲完...感觉得还可以...对着模板打了个模板...还是不喜欢用指针.... 1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Lim ...
- C++之路进阶——codevs2460(树的统计)
2460 树的统计 2008年省队选拔赛浙江 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 一棵树上有n个节 ...
- BZOJ 1036 树的统计-树链剖分
[ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 12904 Solved: 5191[Submit][Status ...
- BZOJ_1036_[ZJOI2008]_树的统计Conut_(树链剖分)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1036 给出一棵树以及各点的权值,对数进行如下三种操作: 1.改变某一节点u的值为t; 2.求节 ...
- bzoj 1036 [ZJOI2008]树的统计Count(树链剖分,线段树)
1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 10677 Solved: 4313[Submit ...
随机推荐
- Oracle-DML- insert & update & delete
说明:语句中说到的“表”,以及表中有哪些“列”自行脑补......重要的是理解概率,能看懂语句代表的含义就OK~ DML-数据操作语句: 1. insert 新增 /*insert into 表名va ...
- (二)Java秒杀项目之实现登录功能
一.数据库设计 CREATE TABLE `miaosha_user` ( `id` ) NOT NULL COMMENT '用户ID,手机号码', `nickname` ) NOT NULL, `p ...
- Minicom 简单使用
一. 什么是minicom 1.1. minicom 是linux 下的一个串口调试工具 二. minicom的使用 2.1. 进入设置 sudo minicom -s 2.1.1. 串口设置 i. ...
- 字符串转数组(php版)
思路: 1.判断当前传来的值是否为数组 2.若不是现将传来的值转换为字符串类型 3.判断当前值是否为空 4.若不为空,采用正则进行匹配,如下图 preg_match('/^{.*?}$/', $str ...
- idea 去除重复代码提醒
- shell脚本之nginx启动脚本、统计日志字段、for循环实战、跳板机
1.NGINX启动脚本 #!/bin/bash # chkconfig: 235 32 62 # description: nginx [ -f /etc/init.d/functions ] &am ...
- Codeforces 1194C. From S To T
传送门 首先贪心, $S$ 能和 $T$ 匹配就要尽量匹配,剩下的才让 $P$ 来补 在 $S$ 全部匹配上的情况下,看看 $P$ 是否有足够的字符即可 #include<iostream> ...
- 二、redis学习(java操作redis缓存的工具jedis)
- java实现spark常用算子之filter
import org.apache.spark.SparkConf;import org.apache.spark.api.java.JavaRDD;import org.apache.spark.a ...
- Vue报错:Property or method "XXX" is not defined on the instance but referenced during render. Make sure that this property is reactive...
在Vue中定义方法或者属性时,因为粗心疏忽可以能会报该错误 [Vue warn]: Property or method "search" is not defined on th ...