[Contest20180116]随机游走
题意:给一棵树,多次询问$a$到$b$期望步数,每一步都是随机的
对期望DP了解更深入了一些
先预处理$up_x$表示从$x$走到$fa_x$的期望步数
可以直接往上走,也可以先去儿子再回来,设$x$的度数为$d_x$
所以$up_x=\dfrac{1}{d_x}+\sum\limits_{p\in son_x}\dfrac{1}{d_x}\left(1+up_p+up_x\right)$
整理得$up_x=d_x+\sum\limits_{p\in son_x}up_p$
再预处理$down_x$表示从$fa_x$走到$x$的期望步数
可以直接往下走,也可以先去其他儿子再回来,也可以先去爷爷再回来
所以$down_x=\dfrac{1}{d_x}+\dfrac{1}{d_x}\left(1+down_{fa_x}+down_x\right)+\sum\limits_{\substack{p\in son_{fa_x}\\p\ne x}}\dfrac{1}{d_x}\left(1+up_p+down_x\right)$
整理得$down_x=down_{fa_x}+up_{fa_x}-up_x$
dp求出$up$和$down$之后求前缀和,用倍增求lca,一上一下的期望直接加起来即可
- #include<stdio.h>
- #define ll long long
- int to[200010],nex[200010],h[100010],d[100010],dep[100010],fa[100010][17],tot;
- ll up[100010],dn[100010];
- void add(int a,int b){
- tot++;
- to[tot]=b;
- nex[tot]=h[a];
- h[a]=tot;
- }
- void dfs1(int x){
- up[x]=d[x];
- for(int i=h[x];i;i=nex[i]){
- if(to[i]!=fa[x][0]){
- fa[to[i]][0]=x;
- dep[to[i]]=dep[x]+1;
- dfs1(to[i]);
- up[x]+=up[to[i]];
- }
- }
- }
- void dfs2(int x){
- for(int i=h[x];i;i=nex[i]){
- if(to[i]!=fa[x][0]){
- dn[to[i]]=dn[x]+up[x]-up[to[i]];
- dfs2(to[i]);
- }
- }
- }
- void dfs3(int x){
- for(int i=h[x];i;i=nex[i]){
- if(to[i]!=fa[x][0]){
- up[to[i]]+=up[x];
- dn[to[i]]+=dn[x];
- dfs3(to[i]);
- }
- }
- }
- void swap(int&a,int&b){a^=b^=a^=b;}
- int lca(int x,int y){
- int i;
- if(dep[x]<dep[y])swap(x,y);
- for(i=16;i>=0;i--){
- if(dep[fa[x][i]]>=dep[y])x=fa[x][i];
- }
- if(x==y)return x;
- for(i=16;i>=0;i--){
- if(fa[x][i]!=fa[y][i]){
- x=fa[x][i];
- y=fa[y][i];
- }
- }
- return fa[x][0];
- }
- int main(){
- int n,m,i,j,a,b;
- scanf("%d",&n);
- for(i=1;i<n;i++){
- scanf("%d%d",&a,&b);
- d[a]++;
- d[b]++;
- add(a,b);
- add(b,a);
- }
- dep[1]=1;
- dfs1(1);
- for(j=1;j<17;j++){
- for(i=1;i<=n;i++)fa[i][j]=fa[fa[i][j-1]][j-1];
- }
- dfs2(1);
- dfs3(1);
- scanf("%d",&m);
- while(m--){
- scanf("%d%d",&a,&b);
- j=lca(a,b);
- printf("%lld\n",up[a]-up[j]+dn[b]-dn[j]);
- }
- }
[Contest20180116]随机游走的更多相关文章
- 【Matlab】随机游走产生图像效果
随机游走类似布朗运动,就是随机的向各个方向走吧.产生的图像实在漂亮,所以还是贴出分享. clear all; close all; clc; n=100000; x= 0; y= 0; pixel=z ...
- 介绍一个全局最优化的方法:随机游走算法(Random Walk)
1. 关于全局最优化求解 全局最优化是一个非常复杂的问题,目前还没有一个通用的办法可以对任意复杂函数求解全局最优值.上一篇文章讲解了一个求解局部极小值的方法--梯度下降法.这种方法对于求解精度不高 ...
- Loj #2542. 「PKUWC2018」随机游走
Loj #2542. 「PKUWC2018」随机游走 题目描述 给定一棵 \(n\) 个结点的树,你从点 \(x\) 出发,每次等概率随机选择一条与所在点相邻的边走过去. 有 \(Q\) 次询问,每次 ...
- LOJ #2542. 「PKUWC 2018」随机游走(最值反演 + 树上期望dp + FMT)
写在这道题前面 : 网上的一些题解都不讲那个系数是怎么推得真的不良心 TAT (不是每个人都有那么厉害啊 , 我好菜啊) 而且 LOJ 过的代码千篇一律 ... 那个系数根本看不出来是什么啊 TAT ...
- 【LOJ2542】【PKUWC 2018】随机游走 min-max容斥 树上高斯消元
题目描述 有一棵 \(n\) 个点的树.你从点 \(x\) 出发,每次等概率随机选择一条与所在点相邻的边走过去. 有 \(q\) 次询问,每次询问给定一个集合 \(S\),求如果从 \(x\) 出发一 ...
- [PKUWC2018] 随机游走
Description 给定一棵 \(n\) 个结点的树,你从点 \(x\) 出发,每次等概率随机选择一条与所在点相邻的边走过去. 有 \(Q\) 次询问,每次询问给定一个集合 \(S\),求如果从 ...
- 【LOJ#2542】[PKUWC2018]随机游走(min-max容斥,动态规划)
[LOJ#2542][PKUWC2018]随机游走(min-max容斥,动态规划) 题面 LOJ 题解 很明显,要求的东西可以很容易的进行\(min-max\)容斥,那么转为求集合的\(min\). ...
- LOJ #2542「PKUWC2018」随机游走
$ Min$-$Max$容斥真好用 $ PKUWC$滚粗后这题一直在$ todolist$里 今天才补掉..还要更加努力啊.. LOJ #2542 题意:给一棵不超过$ 18$个节点的树,$ 5000 ...
- 「PKUWC2018」随机游走(min-max容斥+FWT)
「PKUWC2018」随机游走(min-max容斥+FWT) 以后题目都换成这种「」形式啦,我觉得好看. 做过重返现世的应该看到就想到 \(min-max\) 容斥了吧. 没错,我是先学扩展形式再学特 ...
随机推荐
- Expect使用小记
By francis_hao May 31,2017 本文翻译了部分Expect的man手册,只选取了个人常用的功能,因此并不完善. Expect是一个可以和交互式程序对话的程序 概述 ...
- SCOI2010 传送带 [三分/模拟退火]
题目描述 在一个2维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段AB和线段CD.lxhgww在AB上的移动速度为P,在CD上的移动速度为Q,在平面上的移动速度R.现在lxh ...
- 存储过程-----DECLARE---实用注意事项
定义与使用变量时需要注意以下几点: ◆ DECLARE语句必须用在DEGIN…END语句块中,并且必须出现在DEGIN…END语句块的最前面,即出现在其他语句之前. ◆ DECLARE定义的变量的作用 ...
- javascript中Date使用总结(转)
//全局函数 Date //Date 类的静态方法 Date.parse Date.UTC //Date 对象的建立方法 new Date() new Date(毫秒数) new Date(标准时间格 ...
- oracle中函数
一:前言 最近决定每天都把知识点总结下,然后每个星期把知识点在进行分类发表日志. 二:The Question (1):在oracle中进行年龄的计算,知道出生日期进行计算后截取,本来是一个很简单的函 ...
- Visual Studio Code 配置C/C++环境
0. 前言 VS Code 是微软发布一款跨平台的源代码编辑器,其拥有强大的功能和丰富的扩展,使之能适合编写许多语言. 本文面向初学者(但不是纯小白),分享一点我配置C/C++的经验. 本文所有内容均 ...
- POJ3682 King Arthur's Birthday Celebration
King Arthur is an narcissist who intends to spare no coins to celebrate his coming K-th birthday. Th ...
- swift mac 使用git, 并使用osc, 打开当前目录命令在终端输入 open . windows 下为start .
使用git.osc而不用github, 因为在osc里面可以设置私有项目,而不需要公开. ssh-keygen -t rsa -C "email@email.com" mac下生成 ...
- 通过监测DLL调用探测Mimikatz
通过Sysmon的-l参数可以探测到DLL加载(ImageLoaded): REF: https://securityriskadvisors.com/blog/post/detecting-in-m ...
- 4.flask数据库
1.安装MySQL 直接去下载即可,如果是windows建可以下载msi,一路next即可.我已经安装过了,这里就不再演示了. 最后使用Navicat连接测试一下,我这里是没有问题的 2.SQLAlc ...