LINK:梦中漫步

当然也可以去一本通的Oj/loj上交(loj可能没有..

期望好题。期望和dp往往是在一起的。

前置知识:1. 期望是线性可加的。2.和的期望等于期望的和.

从u出发每次随机选一条边走 问走到v的期望经过的边数。

寒假的时候就在思考这道题了 当时yy了一个LCA乱搞的方法 wa的不省人事。

重新分析:考虑设\(f_i\)表示从u出发到i这个点的期望经过的边数。

列出转移 发现转移有环 暴力高斯消元 显然不可行。

刚才列出的两个知识 和的期望等于期望的和。

这个东西告诉我们 u->v的期望边数=u->fu->ffu->fffu->...v的期望边数。

于是可以设出两个期望数组.

\(f1_x\)表示由x到fx的经过的期望边数。\(f2_x\)表示fx到x的期望边数。

只要求出这个两个数组我们就可以利用求出LCA 求出路径上的这两个数组的和 得到答案。

考虑\(f1\)怎么求 设d表示x的度数\(f1_x=\frac{1}{d}+\sum_{v\in son_x}\frac{1}{d}(1+f1_v+f1_x)\)

化简可得 \(f1_x=d+\sum_{v\in son_x}f1_v\)

考虑\(f2\) 设d表示x的父亲的度数\(f2_x=\frac{1}{d}+\frac{1}{d}(1+f2_{fa}+f2_x)+\sum_{v\in son_x,v\neq x}\frac{1}{d}(1+f1_v+f2_x)\)

化简可得 \(f2_x=d+f2_{fa}+\sum_{v\in son_x,v\neq x}f1_v\)

然后树上取前缀和 求LCA即可O(1)计算答案。

复杂度Qlogn.

const int MAXN=100010;
int n,Q,len;
int du[MAXN],d[MAXN];
int f[MAXN][20],Log[MAXN];
ll f1[MAXN],ans,f2[MAXN];//f1[x]表示由x走到fx的期望边数.f2[x]表示由fx走到x的期望边数.
int lin[MAXN],ver[MAXN<<1],nex[MAXN<<1];
inline void add(int x,int y)
{
ver[++len]=y;
nex[len]=lin[x];
lin[x]=len;++du[y];
}
inline void dfs(int x,int fa)
{
f[x][0]=fa;d[x]=d[fa]+1;
rep(1,Log[d[x]],i)f[x][i]=f[f[x][i-1]][i-1];
f1[x]=du[x];
go(x)if(tn!=fa)dfs(tn,x),f1[x]=(f1[x]+f1[tn])%mod;
}
inline void dp(int x,int fa)
{
if(x!=1)f2[x]=((f2[fa]+f1[fa]-f1[x])%mod+mod)%mod;
go(x)if(tn!=fa)dp(tn,x);
}
inline void dfs(int x)
{
go(x)if(tn!=f[x][0])f1[tn]=(f1[tn]+f1[x])%mod,f2[tn]=(f2[tn]+f2[x])%mod,dfs(tn);
}
inline int LCA(int x,int y)
{
if(d[x]>d[y])swap(x,y);
for(int i=Log[d[y]];i>=0;--i)
if(d[f[y][i]]>=d[x])y=f[y][i];
if(x==y)return x;
for(int i=Log[d[x]];i>=0;--i)
if(f[x][i]!=f[y][i])
x=f[x][i],y=f[y][i];
return f[x][0];
}
int main()
{
freopen("1.in","r",stdin);
//freopen("wanderindream.in","r",stdin);
//freopen("wanderindream.out","w",stdout);
n=read();Q=read();
for(int i=2;i<=n;++i)
{
int x,y;
x=read();y=read();
add(x,y);add(y,x);
Log[i]=Log[i>>1]+1;
}
dfs(1,0);dp(1,0);dfs(1);
for(int i=1;i<=Q;++i)
{
int x,y;
x=read();y=read();
if(x==y){puts("0");continue;}
int lca=LCA(x,y);
ans=f1[x]-f1[lca];
ans=(ans+f2[y]-f2[lca])%mod;
ans=(ans+mod)%mod;
putl(ans);
}
return 0;
}

非常妙的期望。

duoxiao OJ #910 【高手训练】【动态规划】梦中漫步 期望 LCA的更多相关文章

  1. BZOJ 3620: 似乎在梦中见过的样子

    似乎在梦中见过的样子.... 一道水题调了这么久,还半天想不出来怎么 T 的...佩服自己(果然蒟蒻) 这题想想 KMP 但是半天没思路瞟了一眼题解发现暴力枚举起始点,然后 KMP 如图: O( n2 ...

  2. 织梦中在线显示pdf文件的方法

    如何在织梦中添加pdf文件并显示呢?下面这个教程将带领大家来操作.(注:手机版无法查看) 第一步:在系统-系统基本参数-附件设置中添加pdf格式 并且将大小调大 第二步:在核心-内容模型-普通文章中添 ...

  3. 【BZOJ 3620】 3620: 似乎在梦中见过的样子 (KMP)

    3620: 似乎在梦中见过的样子 Time Limit: 15 Sec  Memory Limit: 128 MBSubmit: 755  Solved: 445 Description “Madok ...

  4. 【BZOJ3620】似乎在梦中见过的样子 KMP

    [BZOJ3620]似乎在梦中见过的样子 Description “Madoka,不要相信 QB!”伴随着 Homura 的失望地喊叫,Madoka 与 QB 签订了契约. 这是 Modoka 的一个 ...

  5. BZOJ_3620_似乎在梦中见过的样子_KMP

    BZOJ_3620_似乎在梦中见过的样子_KMP Description “Madoka,不要相信 QB!”伴随着 Homura 的失望地喊叫,Madoka 与 QB 签订了契约. 这是 Modoka ...

  6. ACM_梦中的函数

    梦中的函数 Time Limit: 2000/1000ms (Java/Others) Problem Description: 寒假那段时间,每天刷题的小G连做梦都是代码,于是有了这道题. 给定一个 ...

  7. 【LOJ#6682】梦中的数论(min_25筛)

    [LOJ#6682]梦中的数论(min_25筛) 题面 LOJ 题解 注意题意是\(j|i\)并且\((j+k)|i\), 不难发现\(j\)和\((j+k)\)可以任意取\(i\)的任意因数,且\( ...

  8. 【kmp】似乎在梦中见过的样子

    参考博客: BZOJ 3620: 似乎在梦中见过的样子 [KMP]似乎在梦中见过的样子 题目描述 「Madoka,不要相信QB!」伴随着Homura的失望地喊叫,Madoka与QB签订了契约. 这是M ...

  9. 似乎在梦中见过的样子 (KMP)

    # 10047. 「一本通 2.2 练习 3」似乎在梦中见过的样子 [题目描述] 「Madoka,不要相信 QB!」伴随着 Homura 的失望地喊叫,Madoka 与 QB 签订了契约. 这是 Mo ...

随机推荐

  1. docker安装,卸载和入门

    Docker 简介 背景 开发和运维之间因为环境不同而导致的矛盾 集群环境下每台机器部署相同的应用 DevOps(Development and Operations) 简介 Docker是一个开源的 ...

  2. 从0开始,手把手教你开发并部署上线一个知识测验微信小程序

    上线项目演示 微信搜索[放马来答]或扫以下二维码体验: 项目源码 项目源码 其他版本 Vue答题App实战教程 Hello小程序 1.注册微信小程序 点击立即注册,选择微信小程序,按照要求填写信息 2 ...

  3. 04 Django模型层: Django-model进阶

    一 QuerySet对象 1.1可切片 使用Python 的切片语法来限制查询集记录的数目 .它等同于SQL 的LIMIT 和OFFSET 子句. Entry.objects.all()[:5] # ...

  4. 【XCTF】Cat

    标签:宽字节.PHP.Django.命令执行 解题过程 目录扫描没有发现任何可疑页面. 测试输入许多域名,均没有反应:输入ip地址得到回显. 猜测为命令执行,尝试使用管道符拼接命令. 测试:|.&am ...

  5. CTF_show平台 web题解 part1

    web3 题目描述: 方法一:RFI 使用url实现php远程文件包含 在服务器上构造1.txt <?php $a = "<?php eval(\$_POST['123'])?& ...

  6. Scala 基础(五):Scala变量 (二) 数据类型

    1 scala数据类型介绍 Scala 与 Java有着相同的数据类型,在Scala中数据类型都是对象,也就是说scala没有java中的原生类型 Scala数据类型分为两大类 AnyVal(值类型) ...

  7. 机器学习实战基础(十七):sklearn中的数据预处理和特征工程(十)特征选择 之 Embedded嵌入法

    Embedded嵌入法 嵌入法是一种让算法自己决定使用哪些特征的方法,即特征选择和算法训练同时进行.在使用嵌入法时,我们先使用某些机器学习的算法和模型进行训练,得到各个特征的权值系数,根据权值系数从大 ...

  8. python 装饰器(二):装饰器基础(二)变量作用域规则,闭包,nonlocal声明

    变量作用域规则 在示例 7-4 中,我们定义并测试了一个函数,它读取两个变量的值:一个是局部变量 a,是函数的参数:另一个是变量 b,这个函数没有定义它. >>> def f1(a) ...

  9. springboot --- 之SSM框架整合

    1.pom依赖: 即:spring-boot的基本jar ---- 内置springmvc和spring Thymeleaf jar 热部署 jar ---方便二次加载 ctrl+f9再次编译 Myb ...

  10. 软件测试工程师应该怎样规划自己?成为年薪30W+测试工程师(乾坤未定,皆是黑马)

    今天在知乎上被邀了一个问题,软件测试工程师应该怎样规划自己?16年毕业,技术方面已经渣到不行,因为之前的公司没有Python自动化测试这个要求,有些迷茫.我把我的问题回答贴出来希望可以帮助到更多有类型 ...