题目描述

首长NOI惨跪,于是去念文化课了。现在,他面对一道化学题。
这题的来源是因为在一个奇怪的学校两个化竞党在玩一个奇怪的博弈论游戏。这个游戏很蛋疼,我相信你们也没有兴趣听。
由于这个游戏涉及博弈论,因此化竞的同学就要求首长求一个类似SG函数的值。
他们手中有一种非常神奇的化合物,它的分子由N个原子组成(不要在意一个原子可能和及其多个原子成键这个细节)。这个分子构成一个树结构,1号分子为根。    若两个原子i、j到它们的最近公共祖先的距离分别是Li和Lj,定义它们的Aij值为:
Aij=Li  xor Lj
题目要求对于每一个k(k∈N),求出两两A值为k的原子对个数。

输入

第一行一个整数N。
接下来N-1行,每行一个整数p,第i行的整数表示第i个原子的父亲为p。

输出

从K=0开始,第k+1行输出两两A值为K的原子对个数,输出到第一个不为零的数为止。

样例输入

3
1
1

样例输出

1
2


题解

树形dp

第一眼看到这题感觉直接上树形dp可能会TLE,然而貌似数据水。

然后随便搞了搞就交上去了, 结果不但没T,而且跑得飞快(CQzhangyu压了压状态然后怒拿rank1)

设f[i][j]表示以i为根的子树中深度为j的节点个数。

考虑答案,枚举x中深度为j的节点和x的儿子s中深度为k的节点,那么显然$ans[(j-deep[x])xor(k-deep[x])]+=f[x][j]*f[s][k]$。

然后再更新x。

上界设的紧一点就可以稳切了。

时间复杂度大概是$O(nh^2)$的。

另外本题亲测不需要开long long

UPD:正解貌似是FWT,然而好像没有暴力快。。。

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <algorithm>
  4. #define N 100010
  5. using namespace std;
  6. int head[N] , to[N] , next[N] , cnt , f[510][N] , deep[N] , md[N] , ans[520];
  7. void add(int x , int y)
  8. {
  9. to[++cnt] = y , next[cnt] = head[x] , head[x] = cnt;
  10. }
  11. void dfs(int x)
  12. {
  13. int i , j , k;
  14. md[x] = deep[x] , f[deep[x]][x] ++ ;
  15. for(i = head[x] ; i ; i = next[i])
  16. {
  17. deep[to[i]] = deep[x] + 1 , dfs(to[i]);
  18. for(j = deep[x] ; j <= md[x] ; j ++ )
  19. for(k = deep[to[i]] ; k <= md[to[i]] ; k ++ )
  20. ans[(j - deep[x]) ^ (k - deep[x])] += f[j][x] * f[k][to[i]];
  21. for(j = deep[to[i]] ; j <= md[to[i]] ; j ++ )
  22. f[j][x] += f[j][to[i]];
  23. md[x] = max(md[x] , md[to[i]]);
  24. }
  25. }
  26. int main()
  27. {
  28. int n , i , x;
  29. scanf("%d" , &n);
  30. for(i = 2 ; i <= n ; i ++ ) scanf("%d" , &x) , add(x , i);
  31. dfs(1);
  32. for(i = 0 ; ans[i] ; i ++ ) printf("%d\n" , ans[i]);
  33. return 0;
  34. }

【bzoj3696】化合物 树形dp的更多相关文章

  1. 【BZOJ3696】化合物 树形DP+暴力

    [BZOJ3696]化合物 Description 首长NOI惨跪,于是去念文化课了.现在,他面对一道化学题.    这题的来源是因为在一个奇怪的学校两个化竞党在玩一个奇怪的博弈论游戏.这个游戏很蛋疼 ...

  2. 【BZOJ-3696】化合物 树形DP + 母函数(什么鬼)

    3696: 化合物 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 165  Solved: 85[Submit][Status][Discuss] D ...

  3. [Bzoj3696]化合物【暴力+树形Dp】

    Online Judge:Bzoj3696 Label:暴力,树形Dp 题目描述 首长NOI惨跪,于是去念文化课了.现在,他面对一道化学题. 这题的来源是因为在一个奇怪的学校两个化竞党在玩一个奇怪的博 ...

  4. 树形dp专题总结

    树形dp专题总结 大力dp的练习与晋升 原题均可以在网址上找到 技巧总结 1.换根大法 2.状态定义应只考虑考虑影响的关系 3.数据结构与dp的合理结合(T11) 4.抽直径解决求最长链的许多类问题( ...

  5. poj3417 LCA + 树形dp

    Network Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 4478   Accepted: 1292 Descripti ...

  6. COGS 2532. [HZOI 2016]树之美 树形dp

    可以发现这道题的数据范围有些奇怪,为毛n辣么大,而k只有10 我们从树形dp的角度来考虑这个问题. 如果我们设f[x][k]表示与x距离为k的点的数量,那么我们可以O(1)回答一个询问 可是这样的话d ...

  7. 【BZOJ-4726】Sabota? 树形DP

    4726: [POI2017]Sabota? Time Limit: 20 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 128  Solved ...

  8. 树形DP+DFS序+树状数组 HDOJ 5293 Tree chain problem(树链问题)

    题目链接 题意: 有n个点的一棵树.其中树上有m条已知的链,每条链有一个权值.从中选出任意个不相交的链使得链的权值和最大. 思路: 树形DP.设dp[i]表示i的子树下的最优权值和,sum[i]表示不 ...

  9. 树形DP

    切题ing!!!!! HDU  2196 Anniversary party 经典树形DP,以前写的太搓了,终于学会简单写法了.... #include <iostream> #inclu ...

随机推荐

  1. Random-数组

    1.能够使用Random生成随机数     1)import java.util.Random;         2)Random r = new Random();       3)r.nextIn ...

  2. css布局:左边固定宽度,右边自适应宽度或右侧固定,左侧自适应三种方法

    方法一:浮动布局 这种方法我采用的是左边浮动,右边加上一个margin-left值,让他实现左边固定,右边自适应的布局效果 HTML Markup <div id="left" ...

  3. 利用UnblockNeteaseMusic实现网易云破版权,并实现shell可快速访问

    注:本篇包含mac及windows下安装方式详细 mac安装 前提:安装有node环境,可参考 mac下安装nodejs 安装 下载git代码到本地 git clone https://github. ...

  4. KTU Programming Camp (Winter Training Day 1)

    A.B.C(By musashiheart) 0216个人赛前三道题解 E(By ggg) Gym - 100735E Restore H(by pipixia) Gym - 100735H

  5. readystatechange

    // alternative to DOMContentLoaded document.onreadystatechange = function () { if (document.readySta ...

  6. CSS BEM 命名规范简介

    [前言] BEM 是一个简单又非常有用的命名约定.让你的前端代码更容易阅读和理解,更容易协作,更容易控制,更加健壮和明确,而且更加严密.这篇文章主要介绍了CSS BEM 命名规范简介(推荐)的相关资料 ...

  7. PAT (Advanced Level) Practise - 1099. Build A Binary Search Tree (30)

    http://www.patest.cn/contests/pat-a-practise/1099 A Binary Search Tree (BST) is recursively defined ...

  8. java在线聊天项目0.7版 连接多个客户端问题,开启多个客户端后服务器端只接收到一个 对各种异常的补充处理

    问题的原因是 while(connected) { String str=dis.readUTF(); System.out.println(str); } 不断循环执行,一直在死循环获取socket ...

  9. 把所有界面的状态栏字体颜色设置为白色--iOS开发系列---项目中成长的知识一

    第一步: 在info.plist中 View controller-based status bar appearance这个属性设置为 View controller-based status ba ...

  10. vue-cli3.0 生产包去除console.log

    目前负责的公众号又迭代了一个版本,之前打生产包,配置总是和测试包搞混,所以使用了vue-cli3.0的环境变量来控制配置. 但是又发现了一个新问题,写代码的过程中写了很多console.log 来调试 ...