hdu 3887 Counting Offspring

题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=3887

题意:给出一棵树,对于每一个节点,问他的子孙节点中有多少个节点小于该节点。

思路:首先找出这棵树的DFS序列,每一个节点出现在两个位置,这两个位置之间的节点就是该节点的子孙节点。

然后用树状数组求出这两个位置之间有多少个节点小于该节点。

hdu这题出的有点龊 ,,用dfs搜索会爆栈,要手动模拟先序或者后序遍历!

code:

ContractedBlock.gifExpandedBlockStart.gifView Code
  1 # include<stdio.h>
2 # include<string.h>
3 # define N 100050
4 struct node{
5 int from,to,next;
6 }edge[2*N],edge1[2*N];
7 int head[N],tol,head1[N],tol1,S[N],s[N],k,dp[N],count[N],visit[N],sig[N];
8 void add(int a,int b)
9 {
10 edge[tol].from=a;edge[tol].to=b;edge[tol].next=head[a];head[a]=tol++;
11 }
12 void add1(int a,int b)
13 {
14 edge1[tol1].from=a;edge1[tol1].to=b;edge1[tol1].next=head1[a];head1[a]=tol1++;
15 }
16 void dfs2(int root)
17 {
18 int j,top,u,v;
19 top=0;
20 k=0;
21 S[++top]=root;
22 while(top>0)
23 {
24 u=S[top];
25 if(!visit[u])
26 {
27 visit[u]=1;
28 s[++k]=u;
29 sig[u]=k;
30 }
31 for(j=head[u];j!=-1;j=edge[j].next)
32 {
33 v=edge[j].to;
34 if(visit[v]) continue;
35 S[++top]=v;
36 break;
37 }
38 if(j==-1)
39 {
40 top--;
41 dp[u]=k-sig[u];
42 }
43 }
44 }
45 void insert(int i)
46 {
47 while(i<=k)
48 {
49 count[i]++;
50 i+=i&(-i);
51 }
52 }
53 int query(int i)
54 {
55 int sum=0;
56 while(i>0)
57 {
58 sum+=count[i];
59 i-=i&(-i);
60 }
61 return sum;
62 }
63 int main()
64 {
65 int i,j,v,n,root,num[N],ans,node,a,b;
66 while(scanf("%d%d",&n,&root)!=EOF)
67 {
68 if(!n && !root) break;
69 tol=0;
70 memset(head,-1,sizeof(head));
71 for(i=1;i<n;i++)
72 {
73 scanf("%d%d",&a,&b);
74 add(a,b);
75 add(b,a);
76 }
77 memset(dp,0,sizeof(dp));
78 //dfs1(root,0);//树形DP求节点子孙的个数
79 memset(visit,0,sizeof(visit));
80 dfs2(root);//模拟栈,先序遍历
81 tol1=0;
82 memset(head1,-1,sizeof(head1));
83 for(i=1;i<=n;i++)
84 {
85 node=s[i];
86 ans=dp[node]+i;
87 add1(ans,node);
88 }
89 memset(count,0,sizeof(count));
90 for(i=1;i<=n;i++)
91 {
92 node=s[i];
93 num[node]=query(node-1);
94 insert(node);
95 for(j=head1[i];j!=-1;j=edge1[j].next)
96 {
97 v=edge1[j].to;
98 num[v]=query(v-1)-num[v];
99 }
100 }
101 printf("%d",num[1]);
102 for(i=2;i<=n;i++)
103 printf(" %d",num[i]);
104 printf("\n");
105 }
106 return 0;
107 }

转载于:https://www.cnblogs.com/183zyz/archive/2011/09/30/2196452.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/267548.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

搭建vue开发环境的步骤

搭建vue开发环境的步骤 相信很多人在刚开始学习vue这个框架的时候&#xff0c;在最开始搭建开发环境的时候&#xff0c;都会遇到一些大大小小的坑&#xff0c;我之前在学习angular的时候搭建过一次&#xff0c;过了一个月后在搭建第二次的时候&#xff0c;竟然有一些混乱&#…

ccxprocess可以禁用么_提效 | 5G时代网站还需要加速么?

看到标题, 你一定会说都已经 5G 时代了, 还要在网络提速上下功夫么? 答案是: 是的. 如果你是做国际或者全球业务的, 会更有体会, 很多国家和地区的网络是非常差的, 说他们停留在 2G 时代也不过分的.即使是国内良好的网络环境下, 做好网络提速, 也是可以提高用户体验以及缓解服…

springboot ---- sts如何启动两个实例

idea 实现启动两个spring boot工程实例的方法 可以参考这篇博客。 因为使用spring tool suite 学习spring cloud 需要实例化两个spring boot 工程来构成一个小小的集群系统&#xff0c; 可以通过sts ,右击选择run as, 使用run configuration..., 配置jvm参数为 -Dserver.portxx…

java trie实现

http://www.riaos.com/ria/5814

如何利用python在一个wen'dang'li_如何利用Python网络爬虫给自己跟朋友来一份穷游攻略!走到哪里穷到哪里的哦!...

【一、项目背景】穷游网提供原创实用的出境游旅行指南、攻略&#xff0c;旅行社区和问答交流平台&#xff0c;以及智能的旅行规划解决方案&#xff0c;同时提供签证、保险、机票、酒店预订、租车等在线增值服务。穷游“鼓励和帮助中国旅行者以自己的视角和方式体验世界”。今天…

ubuntu下命令安装与卸载软件方法

2019独角兽企业重金招聘Python工程师标准>>> 刚 刚接触ubuntu就开始一直在安装语言包、升级、常用软件和其它相关依赖等等东西&#xff0c;总的来说&#xff0c;是一个劲儿的装&#xff0c;缺全然不知怎么卸载&#xff0c;现在把安装和卸载写 在一块&#xff0c;一旦…

为什么用线程池

1、创建/销毁线程伴随着系统开销&#xff0c;过于频繁的创建/销毁线程&#xff0c;会很大程度上影响处理效率 2、线程并发数量过多&#xff0c;抢占系统资源从而导致阻塞 3、对线程进行一些简单的管理 延时执行、定时循环执行的策略等 https://www.cnblogs.com/dongguacai/p/60…

delphi7存取配置文件与sqlserver数据库连接_Delphi7存取配置文件与SQLServer数据库连接...

时间:2012-06-28 18:57来源:未知 整理:寂涯网络 点击:2975次引言Delphi7 具有强大的数据库应用程序开发功能 在使用Delphi7 开发 房产管理系统 时&#xff0c;后台数据库采用 SQLServer 数据库管理系统 使用 TADOConnection 组件与数据库建立连接&#xff0c;需要指定 TADOConn…

C 语言和C++语言的 struct对比

C 语言和C语言的 struct对比 author: stonehat 1. C语言将struct当成类来处理的&#xff0c;所以C的struct可以包含C类的所有东西&#xff0c;例如构造函数&#xff0c;析构函数&#xff0c;友元等&#xff0c;C的struct和C类唯一不同就是 struct成员默认的是public&#xff0c…

UOJ.117.欧拉回路

题目链接 这数据。。简直了 有自环和重边&#xff0c;有些点可能没有连边(并查集不好使 就DFS吧) 因为重边自环可能非常多&#xff0c;同一个点可能经过n次&#xff0c;所以必须要重置表头H[x](类似当前弧优化) 另外是找欧拉回路不是欧拉路径&#xff0c;判断不要错 无向图: 所…

c++ linux 线程等待与唤醒_C++并发编程 等待与唤醒

C并发编程 等待与唤醒条件变量条件变量, 包括(std::condition_variable 和 std::condition_variable_any)定义在 condition_variable 头文件中, 它们都需要与互斥量(作为同步工具)一起才能工作.std::condition_variable 允许阻塞一个线程, 直到条件达成.成员函数void wait(std:…

iOS 动画基础总结篇

iOS 动画基础总结篇 动画的大体分类(个人总结可能有误) 分类.png UIView 动画 属性动画 12345678910111213141516171819[UIView beginAnimations:nil context:nil];[UIView setAnimationDelay:1];[UIView setAnimationDuration:2];[UIView setAnimationRepeatCount:100];[UIVie…

最老程序员创业札记:全文检索、数据挖掘、推荐引擎应用41

入局在北京初冬寒风的吹拂下&#xff0c;吴言渐渐清醒了起来&#xff0c;他现在需要做的是赶紧想办法应付下周赵海波要召开的会议&#xff0c;而不是无谓的生气。吴言走在冬日的街头&#xff0c;一边走一边想。下周的事情还真不少&#xff0c;第一件事是赵海波要召开的公司改组…

bootstraptable获得所有行_郎酒领衔,2020“川酒全国行”首站香满花城

12月8日&#xff0c;2020“川酒全国行”首站在广州开启。以“川酒金花醉美珠江”为主题&#xff0c;本次活动由四川省经济和信息化厅指导&#xff0c;四川中国白酒金三角酒业协会主办&#xff0c;四川郎酒股份有限公司承办&#xff0c;五粮液、泸州老窖、剑南春、舍得、水井坊协…

判断DataRow中某列是否为空的方法

DataRow drdt.Rows[0]; if(!dr.IsNull("列名")) { //不为空的操作 }转载于:https://www.cnblogs.com/12go/archive/2011/10/09/2203606.html

centos7根据端口查进程_记录一次CentOs7下Nginx+WSGI部署Django项目(超详细)

记录一次Django部署的文章&#xff0c;不是很熟悉Linux系统&#xff0c;踩了不少坑&#xff0c;本篇文章相当于是一个总结&#xff0c;我会在本文中详细介绍&#xff0c;部署单个Django项目和多个Django的方法&#xff0c;如读者有更好的方法&#xff0c;欢迎留言一起探讨~长话…

淘宝跨域获取Cookie分析

最近在发现使用Taobao的时候的一个小细节&#xff0c;于是便萌发起了写这篇文章。 当我们在 www.taobao.com 中进行登录之后&#xff0c;然后直接切换到 www.tmall.com 域名下&#xff0c;发现www.tmall.com首页的最顶部马上显示成了&#xff1a; 您好, andyfaces。 首先&#…

mqtt 传文件断开连接的原因_MQTT PythonClient断开连接不当

MikeScotty的回答不对。缺少的是启动MQTT网络循环。需要启动循环来处理发送keep-alive包、为QoS 1/2消息进行多段握手以及处理传入的订阅。在如果你只想保持联系或者10秒钟&#xff0c;那么这样的方法就可以了import paho.mqtt.client as mqttimport timeBroker "192.168…

JAVA方法 字符串与unicode的相互转换

unicode编码简而言之就是将每一个字符用16位2进制数标识。但是通常都用4位的16进制数标识。例如&#xff1a;1)中文字符串"你好"的unicode码为&#xff1a;\u<?XML:NAMESPACE PREFIX ST1 />4f60\u597d; 2)英文字符串"ab"的unicode码为&#xff1a;…

js原型和原型链

我们要理解js的原型&#xff0c;首先需要知道5条js原型规则&#xff1a; 1.js引用类型(function ,array ,object)都可以任意扩展自己的属性。 1 function fn(){2 3 }4 fn.age10;5 console.log(fn.age);//106 7 var arr[1,2,3];8 arr.namekeke;9 console.log(arr);//[1,2,3,name…