P1291 [SHOI2002]百事世界杯之旅

声明:本博客所有题解都参照了网络资料或其他博客,仅为博主想加深理解而写,如有疑问欢迎与博主讨论✧。٩(ˊᗜˋ)و✧*。

题目描述

“……在 \(2002\) 年 \(6\) 月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字。只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯。还不赶快行动!”

你关上电视,心想:假设有 \(n\) 个不同的球星名字,每个名字出现的概率相同,平均需要买几瓶饮料才能凑齐所有的名字呢?

输入格式

整数 \(n(2≤n≤33)\) ,表示不同球星名字的个数。

输出格式

输出凑齐所有的名字平均需要买的饮料瓶数。如果是一个整数,则直接输出,否则应该直接按照分数格式输出,例如五又二十分之三应该输出为(复制到记事本):\(5\dfrac{3}{20}\)



第一行是分数部分的分子,第二行首先是整数部分,然后是由减号组成的分数线,第三行是分母。减号的个数应等于分母的为数。分子和分母的首位都与第一个减号对齐。

分数必须是不可约的。


Solution

第一道期望 \(dp\) ,虽然说很水 但还是用了一些时间才弄懂的...

设目前已经拿了 \(i\) 个球星(由于球星是无序的,所以先拿后拿没区别),现在由 \(f_i\) 来推 \(f_{i+1}\)

则下一个瓶子能抽到不属于已拿的 \(i\) 个球星的概率为 \(\dfrac{n-i}{n}\)

下下个瓶子能抽到的概率,则是要求在下一个时抽到属于已拿 \(i\) 个中的瓶子,于是概率为 \(\dfrac{i}{n} * \dfrac{n - i}{n}\)

下下下个概率为 \(\left(\dfrac{i}{n}\right)^2*\dfrac{n - i}{n}\)

......

第 \(k\) 个瓶子的概率为 \(\left(\dfrac{i}{n}\right)^{k - 1} * \dfrac{n - i}{n}\)

此时的第 \(k\) 次为极限状态,无穷大次

则期望 \(E=1 * \dfrac{n-i}{n} + 2 * \dfrac{i}{n} * \dfrac{n - i}{n} + 3 * \left(\dfrac{i}{n}\right)^2*\dfrac{n - i}{n} + ... + k * \left(\dfrac{i}{n}\right)^{k - 1} * \dfrac{n - i}{n}\)

将式子两边乘以 \(\dfrac{i}{n}\) 得

\(\dfrac{i}{n}E= 1 * \dfrac{i}{n} * \dfrac{n - i}{n} + 2 * \left(\dfrac{i}{n}\right)^2*\dfrac{n - i}{n} + ... + k * \left(\dfrac{i}{n}\right)^{k} * \dfrac{n - i}{n}\)

两式错位相减再将等式两边乘以 \(\dfrac{n - i}{n}\) 得

\(E=1 + \dfrac{i}{n} + \left(\dfrac{i}{n}\right) ^ 2 + ... + \left(\dfrac{i}{n}\right) ^ k\)

有等比数列求和公式 \(\dfrac{a_1(1 - q^n)}{1 - q}\) 得

\(E=\left(\dfrac{n}{n - i}\right)\)

即 \(f_{i + 1} = f_i + \left(\dfrac{n}{n - i}\right)\)

通过递推合并提项得

\(f_n=n * \left(1 + \dfrac{1}{2} + \dfrac{1}{3} + ... + \dfrac{1}{n}\right)\)

这个式子是不是很漂亮很美观 \(2333\) ,接下来就很简单啦 如果忽略这恶心的输出格式


Code

#include<bits/stdc++.h>
#define ll long long
#define F(i, x, y) for(int i = x; i <= y; ++ i)
using namespace std;
int n;
struct node{
ll a, b;
}ans;
int weishu(ll x)
{
int k = 0;
while(x) x /= 10, ++ k;
return k;
}
ll gcd(ll x, ll y){return (x % y == 0) ? y : gcd(y, x % y);}
int main()
{
scanf("%d", &n);
ans.b = 1;
F(i, 1, n)
{
ans.a = ans.a * i + ans.b, ans.b = ans.b * i;
ll k = gcd(ans.b, ans.a);
ans.a /= k, ans.b /= k;
}
ans.a *= n;
ll k = gcd(ans.b, ans.a);
ans.a /= k, ans.b /= k;
if(ans.b == 1) {printf("%lld\n", ans.a); return 0;}
k = ans.a / ans.b, ans.a -= k * ans.b;
int l1 = weishu(k), l2 = weishu(ans.b);
F(i, 1, l1) printf(" "); printf("%lld\n", ans.a);
if(k) printf("%lld", k);
F(i, 1, l2) printf("-"); printf("\n");
F(i, 1, l1) printf(" "); printf("%lld\n", ans.b);
return 0;
}

【题解】P1291 百事世界杯之旅 - 期望dp的更多相关文章

  1. 洛谷P1291 [SHOI2002]百事世界杯之旅(期望DP)

    题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶 ...

  2. 洛谷P1291 [SHOI2002]百事世界杯之旅——期望DP

    题目:https://www.luogu.org/problemnew/show/P1291 水水的经典期望DP: 输出有毒.(其实也很简单啦) 代码如下: #include<iostream& ...

  3. LUOGU P1291 [SHOI2002]百事世界杯之旅 (期望dp)

    传送门 解题思路 期望$dp$.因为这个是期望步数,所以要倒着推.那么这道题就变得一脸可做了,设$f[i]$表示还有$i$张牌没有收集的期望,那么考虑再抽一张,有$(n-i)/n$的概率抽到抽过的牌, ...

  4. 洛谷P1291 百事世界杯之旅

    P1291 百事世界杯之旅 题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听, ...

  5. 洛谷P1291 [SHOI2002]百事世界杯之旅 [数学期望]

    题目传送门 百事世界杯之旅 题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听, ...

  6. 洛谷 P1291 [SHOI2002]百事世界杯之旅 解题报告

    P1291 [SHOI2002]百事世界杯之旅 题目描述 "--在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽 ...

  7. 「SHOI2002」「LuoguP1291」百事世界杯之旅(UVA10288 Coupons)(期望,输出

    题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶 ...

  8. 【Luogu1291】百事世界杯之旅(动态规划,数学期望)

    [Luogu1291]百事世界杯之旅(动态规划,数学期望) 题面 洛谷 题解 设\(f[i]\)表示已经集齐了\(i\)个名字的期望 现在有两种方法: 先说我自己的: \[f[i]=f[i-1]+1+ ...

  9. luogu P1291 [SHOI2002]百事世界杯之旅

    题目链接 luogu P1291 [SHOI2002]百事世界杯之旅 题解 设\(f[k]\)表示还有\(k\)个球员没有收集到的概率 再买一瓶,买到的概率是\(k/n\),买不到的概率是\((n-k ...

随机推荐

  1. 干货 | NLP算法岗大厂面试经验与路线图分享

    最近有好多小伙伴要面经(还有个要买简历的是什么鬼),然鹅真的没有整理面经呀,真的木有时间(。 ́︿ ̀。).不过话说回来,面经有多大用呢?最起码对于NLP岗位的面试来说,作者发现根本不是面经中说的样子 ...

  2. python文件调用方法

    文件输入输出 open函数可以对文本文件进行读写的操作 基本形式: open(filename,mode) filename是文件名,可以写为绝对路径也可以是相对路径 mode是打开模式. open函 ...

  3. 深入理解NIO(一)—— NIO的简单使用及其三大组件介绍

    深入理解NIO(一)—— NIO的简单使用及其三大组件介绍 深入理解NIO系列分为四个部分 第一个部分也就是本节为NIO的简单使用(我很少写这种新手教程,所以如果你是复习还好,应该不难理解这篇,但如果 ...

  4. Matlab——m_map指南(2)

    3.海岸线和深度测量 3.1.1 海岸线选项 m_coast('line', ...optional line arguments ); m_coast('line', ...optional lin ...

  5. ATM购物车+三层结构项目设计

    ATM购物车项目 模拟实现一个ATM + 购物商城程序. 该程序实现普通用户的登录注册.提现充值还款等功能,并且支持到网上商城购物的功能. 账户余额足够支付商品价格时,扣款支付:余额不足时,无法支付, ...

  6. while实现2-3+4-5+6...+100 的和

    while实现2-3+4-5+6...+100 的和 可以看到规律为2-100内所有奇数都为减法,偶数为加法 设定变量 total=0: count=2 当count为偶数时与total相加,反则相减 ...

  7. KVC讲解

    今天趁着项目bug修复完了,来讲解一下OC知识的另一个技术点-KVC!针对KVC,讲解两个知识点 通过KVC修改属性会触发KVO么? KVC的赋值过程是怎样的?原理是什么? KVC的取值过程是怎样的? ...

  8. Step by Step!教你如何在k3s集群上使用Traefik 2.x

    本文来自边缘计算k3s社区 作者简介 Cello Spring,瑞士人.从电子起步,拥有电子工程学位.尔后开始关注计算机领域,在软件开发领域拥有多年的工作经验. Traefik是一个十分可靠的云原生动 ...

  9. 《Three.js 入门指南》3.1.1 - 基本几何形状 -圆环面(TorusGeometry)

    3.1 基本几何形状 圆环面(TorusGeometry) 构造函数 THREE.TorusGeometry(radius, tube, radialSegments, tubularSegments ...

  10. 跟面试官侃半小时MySQL事务,说完原子性、一致性、持久性的实现

    提到MySQL的事务,我相信对MySQL有了解的同学都能聊上几句,无论是面试求职,还是日常开发,MySQL的事务都跟我们息息相关. 而事务的ACID(即原子性Atomicity.一致性Consiste ...