题目链接:

  http://codeforces.com/problemset/problem/696/B

题目大意:

  给一棵树,从根节点开始递归,time=1,每次递归等概率随机访问这个节点的子节点,走过不会再走,每访问到一个新节点time+1,求访问每个节点的时间的期望。

题目思路:

  【数学规律】

  这题其实是一道概率DP的题目,但是找规律后发现答案和当前结点的子树大小有关。

  ans[v]=ans[u]+1+0.5*(child[u]-child[v]-1),child为当前节点的子树大小。

  1. //
  2. //by coolxxx
  3. ////<bits/stdc++.h>
  4. #include<iostream>
  5. #include<algorithm>
  6. #include<string>
  7. #include<iomanip>
  8. #include<memory.h>
  9. #include<time.h>
  10. #include<stdio.h>
  11. #include<stdlib.h>
  12. #include<string.h>
  13. //#include<stdbool.h>
  14. #include<math.h>
  15. #define min(a,b) ((a)<(b)?(a):(b))
  16. #define max(a,b) ((a)>(b)?(a):(b))
  17. #define abs(a) ((a)>0?(a):(-(a)))
  18. #define lowbit(a) (a&(-a))
  19. #define sqr(a) ((a)*(a))
  20. #define swap(a,b) ((a)^=(b),(b)^=(a),(a)^=(b))
  21. #define mem(a,b) memset(a,b,sizeof(a))
  22. #define eps (1e-8)
  23. #define J 10
  24. #define MAX 0x7f7f7f7f
  25. #define PI 3.14159265358979323
  26. #define N 100004
  27. using namespace std;
  28. typedef long long LL;
  29. int cas,cass;
  30. int n,m,lll,ans;
  31. int fa[N],s[N],last[N];
  32. double c[N];
  33. struct xxx
  34. {
  35. int next,to;
  36. }a[N];
  37. void add(int x,int y)
  38. {
  39. a[++lll].next=last[x];
  40. a[lll].to=y;
  41. last[x]=lll;
  42. }
  43. void cal(int u)
  44. {
  45. int i,v;
  46. for(i=last[u];i;i=a[i].next)
  47. {
  48. v=a[i].to;
  49. cal(v);
  50. s[u]+=s[v];
  51. }
  52. s[u]++;
  53. }
  54. void dfs(int u)
  55. {
  56. int i,v;
  57. for(i=last[u];i;i=a[i].next)
  58. {
  59. v=a[i].to;
  60. c[v]=c[u]+(s[u]-s[v]-)*0.5+;
  61. dfs(v);
  62. }
  63. }
  64. void print()
  65. {
  66. int i;
  67. for(i=;i<=n;i++)
  68. {
  69. printf("%d ",s[i]);
  70. }
  71. puts("");
  72. }
  73. int main()
  74. {
  75. #ifndef ONLINE_JUDGE
  76. freopen("1.txt","r",stdin);
  77. // freopen("2.txt","w",stdout);
  78. #endif
  79. int i,j;
  80. // for(scanf("%d",&cas);cas;cas--)
  81. // for(scanf("%d",&cas),cass=1;cass<=cas;cass++)
  82. // while(~scanf("%s",s))
  83. while(~scanf("%d",&n))
  84. {
  85. mem(s,);mem(last,);lll=;
  86. for(i=;i<=n;i++)
  87. {
  88. scanf("%d",&fa[i]);
  89. add(fa[i],i);
  90. }
  91. cal();
  92. c[]=1.0;
  93. dfs();
  94. for(i=;i<=n;i++)
  95. printf("%.1lf ",c[i]);
  96. puts("");
  97. }
  98. return ;
  99. }
  100. /*
  101. //
  102.  
  103. //
  104. */

【数学相关、规律】Codeforces 696B Puzzles的更多相关文章

  1. CodeForces - 696B Puzzles

    http://codeforces.com/problemset/problem/696/B 题目大意: 这是一颗有n个点的树,你从根开始游走,每当你第一次到达一个点时,把这个点的权记为(你已经到过不 ...

  2. codeforces 696B Puzzles 树形概率计算

    题意:给一棵有根树,从根节点深搜,每次随机走,问每个点的dfs序的期望是多少 分析:对于每一个点,它的所有祖先节点dfs序肯定在它之前,它所在的子树的节点一定在它后面, 剩下的是既不是子树又不是祖先的 ...

  3. codeforces 687B - Remainders Game 数学相关(互质中国剩余定理)

    题意:给你x%ci=bi(x未知),是否能确定x%k的值(k已知) ——数学相关知识: 首先:我们知道一些事情,对于k,假设有ci%k==0,那么一定能确定x%k的值,比如k=5和ci=20,知道x% ...

  4. [自用]多项式类数学相关(定理&证明&板子)

    写在前面 由于上一篇总结的版面限制,特开此文来记录 \(OI\) 中多项式类数学相关的问题. 该文启发于Miskcoo的博客,甚至一些地方直接引用,在此特别说明:若文章中出现错误,烦请告知. 感谢你的 ...

  5. [总结]多项式类数学相关(定理&证明&板子)

    目录 写在前面 前置技能 多项式相关 多项式的系数表示 多项式的点值表示 复数相关 复数的意义 复数的基本运算 单位根 代码相关 多项式乘法 快速傅里叶变换 DFT IDFT 算法实现 递归实现 迭代 ...

  6. [总结]其他杂项数学相关(定理&证明&板子)

    目录 写在前面 一类反演问题 莫比乌斯反演 快速莫比乌斯变换(反演)与子集卷积 莫比乌斯变换(反演) 子集卷积 二项式反演 内容 证明 应用举例 另一形式 斯特林反演 第一类斯特林数 第二类斯特林数 ...

  7. 【3D研发笔记】之【数学相关】(一):坐标系

    现在开始学习3D基础相关的知识,本系列的数学相关笔记是基于阅读书籍<3D数学基础:图形与游戏开发>而来,实现代码使用AS3,项目地址是:https://github.com/hammerc ...

  8. [总结]数论和组合计数类数学相关(定理&证明&板子)

    0 写在前面 0.0 前言 由于我太菜了,导致一些东西一学就忘,特开此文来记录下最让我头痛的数学相关问题. 一些引用的文字都注释了原文链接,若侵犯了您的权益,敬请告知:若文章中出现错误,也烦请告知. ...

  9. Python学习笔记17:标准库之数学相关(math包,random包)

    前面几节看得真心累.如今先来点简单easy理解的内容. 一 math包 math包主要处理数学相关的运算. 常数 math.e   # 自然常数e math.pi  # 圆周率pi 运算函数 math ...

随机推荐

  1. oracle的安装与plsql的环境配置

    1,首先得有oracle的安装包和plsql的安装包,安装包地址可见百度云 http://pan.baidu.com/s/1miTqhmg 2.解压下来进入0817账套,找到set.exe文件,双击安 ...

  2. Spire.Barcode好用的条码生在组件

    由于项目的需要,今天在网上找了一下条码的组件,发现了一个简单易用的组件,使用简单,几句代码就搞定了.

  3. Java实现ajax

    jsp端的代码,sucess:function(){} 里面就是返回的处理 function ChangeTime(){ alert("www"); var startYmd = ...

  4. 使用JavaScriptSerializer序列化集合、字典、数组、DataTable为JSON字符串 分类: 前端 数据格式 JSON 2014-10-30 14:08 169人阅读 评论(0) 收藏

    一.JSON简介 JSON(JavaScript Object Notation,JavaScript对象表示法)是一种轻量级的数据交换格式. JSON是"名值对"的集合.结构由大 ...

  5. ToString格式.

    C 货币 2.5.ToString("C") ¥2.50 D 十进制数 25.ToString("D5") 00025 E 科学型 25000.ToString ...

  6. SQL SERVER将指定表中的指定字段按照(,)逗号分隔

    不开心呀,早知道不跳了,一跳跳坑里来了. 使用方式: DECLARE @ConsigneeAddressId INT; SET @ConsigneeAddressId = 1; SELECT  * F ...

  7. HTTP could not register URL http://+:8000/.... Your process does not have access rights to this namespace

    windows 7, Visual Studio 2013 在托管 Windows 服务中承载 WCF 服务时报错: HTTP could not register URL http://+:8000 ...

  8. anjularjs slider控件替代方案

    做项目需要一个slider控件,找了很久没有找到合适的指令集,无意间看到可以直接用range替代,不过样式有点丑. <label> <input type="range&q ...

  9. Deep Learning 学习随记(四)自学习和非监督特征学习

    接着看讲义,接下来这章应该是Self-Taught Learning and Unsupervised Feature Learning. 含义: 从字面上不难理解其意思.这里的self-taught ...

  10. ITEXTSHARP学习整理

    学习的版本iTextSharp.5.5.5. 关于获取PDF中的图片资源 /// <summary> /// 将PDF中的图片资源转换成二进制 /// </summary> / ...