码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 期望+拆贡献+充斥:CF1349D


    第一步:找性质

    每个人的期望步数只与总数量 m m m,总人数 n n n,自己数量 a i a_i ai​ 有关

    第二步:转化(难点)

    1. 拆贡献:拆成每个人win的期望步数,然后求 ∑ E ( i ) \sum E(i) ∑E(i)
    2. 容斥:肯定不能直接算。于是考虑算直到第 i i i 个人拿完才结束的的期望步数
    3. 继续拆贡献:考虑具体容斥。就是算每个人对这个人拿完的贡献, E ( i ) = E ′ ( i ) − ∑ j ≠ i ( P ( i ) C + E ( i ) ) E(i)=E'(i)-\sum_{j\ne i}(P(i)C+E(i)) E(i)=E′(i)−∑j=i​(P(i)C+E(i)), C C C 表示从无到有的期望步数
    4. 结合性质:设 f i f_i fi​ 表示当前有 i i i 个,win的概率。win指的是这个人win才真正win。则 E ′ ( i ) = f a i , C = f 0 E'(i)=f_{a_i},C=f_0 E′(i)=fai​​,C=f0​
    5. 消掉 E ( i ) E(i) E(i):考虑涉及全部,则直接求 ∑ E ( i ) \sum_{E(i)} ∑E(i)​,然后就可以约去了

    第三步:推式子

    然后发现就是求 f f f, f f f 直接式子可以简单列出来。然后化简参见上一篇博客

    最后考虑 g 0 g_0 g0​ 怎么算。 g 0 g_0 g0​ 本质是获得饼干的期望步数,因为概率 1 n − 1 \frac 1 {n-1} n−11​,所以期望是 n − 1 n-1 n−1

    	n=read(); init(N-1); 
    	for(i=1; i<=n; ++i) a[i]=read(), m+=a[i]; 
    	g[0]=n-1; 
    	for(i=1; i<N; ++i) Add(g[i], g[i-1]*i%mo*(n-1)%mo*inv[m-i]%mo+m*(n-1)%mo*inv[m-i]%mo); 
    	f[m]=0; 
    	for(i=m-1; i>=0; --i) Add(f[i], g[i]+f[i+1]); 
    	Add(ans, -(n-1)*f[0]); 
    	for(i=1; i<=n; ++i) Add(ans, f[a[i]]); 
    	Mul(ans, inv[n]); 
    	printf("%lld", ans); 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
  • 相关阅读:
    线性代数学习笔记9-4:复习——相似矩阵、对角化、对称矩阵
    打通Web安全思路:为什么我们需要同源策略?
    MAC电脑4个隐藏技巧
    MongoDB入门学习(一)
    短视频矩阵系统软件源码
    Vuex使用一文搞懂
    基于Vertx实现可配置及可扩展的IOT服务
    [JavaScript]构造函数创造对象,基本包装类型
    LM小型可编程控制器软件(基于CoDeSys)笔记二十:plc通过驱动器控制步进电机
    nuc980学习笔记7-设置开机自启动
  • 原文地址:https://blog.csdn.net/zhangtingxiqwq/article/details/133753187
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号