码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • CF696B Puzzles 题解


    传送门: 洛谷 CF696B Puzzles

    首先在此感谢 @OneZzz6174 大佬提供的学术支持。

    思路

    对于一个节点 i i i 的期望时间戳,我们记为 f i f_i fi​。

    与其他题解所述相似,我们根据 i i i 的父亲节点和它的兄弟节点可以得到 f i f_i fi​。

    具体地,它的兄弟节点对它的贡献(也是从它的父亲走到它这个节点的概率)是 s i z f a − s i z u − 1 2 \dfrac{siz_{fa}-siz_u-1}{2} 2sizfa​−sizu​−1​。

    然后就可以得到 f i = f f a + s i z f a − s i z u − 1 2 + 1 f_i=f_{fa} + \dfrac{siz_{fa}-siz_u-1}{2} + 1 fi​=ffa​+2sizfa​−sizu​−1​+1。

    其他挺多题解大致都说到这里。

    所以我不妨来说说最后那个加一是怎么来的。

    上面得到 f i f_i fi​ 的式子中,中间那一项,无疑是父亲走到节点 i i i 的概率,但是要注意此题求的是每个节点的期望时间戳,所以在走到节点 i i i 的时候,时间戳要加一,这就是最后一个加一的缘由。

    代码实现

    #include
    using namespace std;
    
    #define rep(i, a, b) for(register int i = a; i <= b; ++i)
    #define per(i, a, b) for(register int i = a; i >= b; --i)
    #define go(u) for(int i = hd[u], v = e[i].to; i; i = e[i].nxt, v = e[i].to)
    #define add(u, v) (e[++cnt].to = v, e[cnt].nxt = hd[u], hd[u] = cnt)
    #define Add(u, v) (add(u, v), add(v, u))
    typedef long long ll ;
    inline int rd(){
    	int x = 1, s = 0; char ch = getchar();
    	while(ch < '0' or ch > '9'){if(ch == '-') x = -1; ch = getchar();}
    	while(ch >= '0' and ch <= '9') s = s * 10 + ch - '0', ch = getchar();
    	return x * s;
    }
    inline void wr(int x){
    	if(x < 0) putchar('-'), x *= -1;
    	if(x > 9) wr(x / 10);
    	putchar(x % 10 + '0');
    }
    //----------------------------------//
    const int maxn = 1e5 + 5;
    int cnt, hd[maxn];
    struct edge{
    	int to, nxt;
    }e[maxn << 1];
    int n, siz[maxn];
    double f[maxn];
    
    inline void dfs1(int u, int fa){
    	siz[u] = 1;
    	go(u) if(v ^ fa)
    		dfs1(v, u), siz[u] += siz[v];
    }
    
    inline void dfs2(int u, int fa){
    	if(fa) f[u] = f[fa] + (siz[fa] - siz[u] - 1.0) / 2.0 + 1.0;
    	go(u) if(v ^ fa) dfs2(v, u);
    }
    
    int main(){
    	n = rd(); int x;
    	rep(i, 2, n) x = rd(), Add(x, i);
    	f[1] = 1.0, dfs1(1, 0), dfs2(1, 0);
    	rep(i, 1, n) printf("%.1lf ", f[i]);
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47

    感谢阅读。

    辛苦管理员审核,如有问题烦请指出。

  • 相关阅读:
    Jenkinsfile 同时检出多个 Git 仓库
    canal五部曲-如何处理insert幂等性的
    计算机毕业设计——税务缴纳信息管理
    初识设计模式 - 装饰器模式
    关于印发《深圳市福田区支持战略性新兴产业和未来产业集群发展若干措施》的通知
    SpringBoot SpringBoot 原理篇 1 自动配置 1.1 bean 的加载方式【一】
    Python爬虫协程批量下载图片
    工作以来一直在CRUD,Spring源码该怎么阅读?这份价值百万的源码解析让你如有神助!
    深度剖析 —— 文件操作
    中间件Weblogic12.2.1.4与iServer 8C 10i兼容性问题解决过程分享
  • 原文地址:https://blog.csdn.net/ez_gsn/article/details/125884676
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号