枚举最终所有牌的大小$i$,对于最终所有牌大小都为$i$的情况,令其贡献为步数,否则令其贡献为0,记$F$为期望贡献(即所有情况概率*贡献之和),答案即为$\sum_{i=1}^{m}F$

显然,$F$仅取决于牌的数量,定义$F_{i}$表示恰有$i$张牌的期望贡献,那么答案即为$\sum_{i=1}^{m}F_{a_{i}}$

在求$F_{i}$的转移之前,先定义$P_{i}$为贡献为步数的情况的概率,关于$P_{i}$的转移,不难得到
$$
\begin{cases}P_{0}=0,P_{n}=1\\P_{i}=\frac{P_{i-1}+P_{i+1}}{2}&(1\le i<n)\end{cases}
$$
这是一个经典的问题,通项为$P_{i}=\frac{i}{n}$

考虑$F_{i}$的转移,即为
$$
\begin{cases}F_{0}=F_{n}=0\\F_{i}=\frac{i(n-i)}{n(n-1)}(F_{i-1}+F_{i+1}+\frac{2i}{n})+(1-\frac{2i(n-i)}{n(n-1)})(F_{i}+\frac{i}{n})&(1\le i<n)\end{cases}
$$
(注意每一次步数并不是+1,而是加上目标状态的$P_{i}$,因为只有$P_{i}$的概率这步有贡献)

将其化简,即为
$$
\begin{cases}F_{0}=F_{n}=0\\F_{i+1}=2F_{i}-F_{i-1}-\frac{n-1}{n-i}&(1\le i<n)\end{cases}
$$
将其差分,即令$G_{i}=F_{i+1}-F_{i}$,那么
$$
\begin{cases}G_{0}=F_{1},\sum_{i=0}^{n-1}G_{i}=0\\G_{i}=G_{i-1}-\frac{n-1}{n-i}&(1\le i<n)\end{cases}
$$
将第2个式子不断迭代,即可得$G_{i}=F_{1}-\sum_{j=1}^{i}\frac{n-1}{n-j}$,那么
$$
\sum_{i=0}^{n-1}G_{i}=nF_{1}-\sum_{i=0}^{n-1}\sum_{j=1}^{i}\frac{n-1}{n-j}=nF_{1}-\sum_{j=1}^{n-1}\frac{n-1}{n-j}(n-j)=nF_{1}-(n-1)^{2}=0
$$
解得$F_{1}=\frac{(n-1)^{2}}{n}$,进而可得
$$
F_{i}=\sum_{j=0}^{i-1}G_{j}=iF_{1}-\sum_{j=1}^{i-1}\frac{n-1}{n-j}(i-j)=\frac{i(n-1)^{2}}{n}-(i-1)(n-1)+(n-i)(n-1)\sum_{j=n-i+1}^{n-1}\frac{1}{j}
$$
(最后一个变化是将$i-j$变形为$(n-j)-(n-i)$,再根据分配律展开即可)

关于最后一项,令$H_{n}=\sum_{i=1}^{n}\frac{1}{i}$,即$H_{n}-H_{n-i}$,关于$H_{n}$为调和级数,用$H_{n}=\ln n+C$来模拟即可(较小范围预处理,$C$使用0.5772即可,当然还可以分块打表)

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 10000005
4 #define C 0.5772
5 #define ld long double
6 int n,m,x;
7 ld nn,ans,h[N];
8 ld H(int n){
9 if (n<N)return h[n];
10 return log(n)+C;
11 }
12 ld calc(int k){
13 return k*(nn-1)*(nn-1)/nn-(k-1)*(nn-1)+(nn-k)*(nn-1)*(H(n-1)-H(n-k));
14 }
15 int main(){
16 for(int i=1;i<N;i++)h[i]=h[i-1]+(ld)1/i;
17 scanf("%d%d",&n,&m);
18 nn=n;
19 for(int i=1;i<=m;i++){
20 scanf("%d",&x);
21 ans+=calc(x);
22 }
23 printf("%.7Lf",ans);
24 }

[loj6118]鬼牌的更多相关文章

  1. LOJ#6118 鬼牌

    \(\rm upd\):是我假了...这题没有爆精...大家要记得这道题是相对误差\(10^{-6}\)...感谢@foreverlasting的指正. 题是好题,可是标算爆精是怎么回事...要写的和 ...

  2. UOJ147 斗地主

    题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关 系根据牌的数码表示如下:3<4&l ...

  3. UOJ 151 斗地主“加强”版

    #151. [NOIP2015]斗地主“加强”版 统计 描述 提交 自定义测试 本题开放Hack 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54 ...

  4. FZU 2216 The Longest Straight(最长直道)

    Description 题目描述 ZB is playing a card game where the goal is to make straights. Each card in the dec ...

  5. Pandas python

    原文:  https://github.com/catalystfrank/Python4DataScience.CH   和大熊猫们(Pandas)一起游戏吧!   Pandas是Python的一个 ...

  6. Python数据分析入门之pandas基础总结

    Pandas--"大熊猫"基础 Series Series: pandas的长枪(数据表中的一列或一行,观测向量,一维数组...) Series1 = pd.Series(np.r ...

  7. 扑克牌(cards)

    扑克牌 思路 这题也是二分!! 我们二分有几套牌,然后再去检验是否符合,至于怎么想到的,不要问我,我也不知道 那么我们主要解决的就是check函数 我们将二分的套数和每种牌的数量进行比较,如果该种牌的 ...

  8. Codeforces 1392H - ZS Shuffles Cards(DP+打表找规律)

    Codeforces 题面传送门 & 洛谷题面传送门 真·两天前刚做过这场的 I 题,今天模拟赛就考了这场的 H 题,我怕不是预言带师 提供一种奇怪的做法,来自于同机房神仙们,该做法不需要 M ...

  9. Solution -「CF 1392H」ZS Shuffles Cards

    \(\mathcal{Description}\)   Link.   打乱的 \(n\) 张编号 \(1\sim n\) 的数字排和 \(m\) 张鬼牌.随机抽牌,若抽到数字,将数字加入集合 \(S ...

随机推荐

  1. struct结构体大小的计算(内存对齐)

    本次实验环境 环境1:Win10, QT 5.12 一. 背景 当普通的类型无法满足我们的需求的时候,就需要用到结构体了.结构体可衍生出结构体数组,结构体还可以嵌套结构体,这下子数据类型就丰富多彩了, ...

  2. [源码解析] PyTorch 流水线并行实现 (6)--并行计算

    [源码解析] PyTorch 流水线并行实现 (6)--并行计算 目录 [源码解析] PyTorch 流水线并行实现 (6)--并行计算 0x00 摘要 0x01 总体架构 1.1 使用 1.2 前向 ...

  3. mysql数据备份及恢复详细操作

    一.数据库数据备份 1.全备 BakDir=/backup/full #创建全备目录 LogFile=/backup/full/bak.log #创建备份日志 Date=`date +%Y%m%d` ...

  4. 一次OutOfMemoryError: GC overhead limit exceeded

    现象: 由于需要将mysql表中的过期数据在凌晨定时读取出过滤后转入到MongoDB,一个转换SQL达到百行,而且有几十个,集中运行后程序反馈异常: Handler dispatch failed; ...

  5. 高效动画实现原理-Jetpack Compose 初探索

    一.简介 Jetpack Compose是Google推出的用于构建原生界面的新Android 工具包,它可简化并加快 Android上的界面开发.Jetpack Compose是一个声明式的UI框架 ...

  6. 【Java技术专题】「性能优化系列」针对Java对象压缩及序列化技术的探索之路

    序列化和反序列化 序列化就是指把对象转换为字节码: 对象传递和保存时,保证对象的完整性和可传递性.把对象转换为有字节码,以便在网络上传输或保存在本地文件中: 反序列化就是指把字节码恢复为对象: 根据字 ...

  7. 5.29日 Scrum Metting

    日期:2021年5月29日 会议主要内容概述:人员调整,xyl同时兼顾前后端:确定表格缩放策略和新图表添加:强调任务分配,总结工作. 一.进度情况## 组员 负责 两日内已完成的工作 后两日计划完成的 ...

  8. Scrum Meeting 0505

    零.说明 日期:2021-5-5 任务:简要汇报两日内已完成任务,计划后两日完成任务 一.进度情况 组员 负责 两日内已完成的任务 后两日计划完成的任务 qsy PM&前端 完成邮箱注册页面功 ...

  9. [技术博客]大闸蟹的技术博客,通过gitlab api进行用户批量创建

    技术博客--通过gitlab api批量注册用户 gitlab登录界面本身提供了register功能,但需要手工一个个添加,对于一次性会添加整个班级的学生的软工平台来说并不科学合理.使用gitlab ...

  10. Codeforces Round #573 (Div. 2) D题题解

    一.题目 ​ Tokitsukaze, CSL and Stone Game ​ Tokitsukaze和CSL正在玩一些石头游戏. ​ 一开始,有n堆的石头,第i堆石头数记为 \(a_i\),两人轮 ...