题解 [SHOI2002] 百事世界杯之旅
其实做这道题还蛮难受的。。。因为这个每一次有无限种可能我有钱我可以去买无限瓶可乐啊但是不是可口我不是很赞同┓( ´∀` )┏
然后参考了这篇题解发现错位相减这样的方法,让我们一起膜拜 ButterflyDew 罢!%%%%%%
不水了这题怎么做捏?首先我们根据期望 dp 的套路令 \(f_i\) 为收集 \(i\) 个不同球星期望可乐瓶数。
这道题为什么不用倒序处理呢?因为没必要,我们会发现倒序处理和正着来是等价的。
好,那么我们考虑如何从 \(f_i\) 转移到 \(f_{i + 1}\)。我们买一次有 \(\dfrac{n - i}{n}\) 的概率买到不同的,如果我们买两次,注意这里我们是恰好有一个没有买到的,如果两次都买到不同球星说明你是个欧皇那么我们就得从 \(f_i\) 转移到 \(f_{i + 2}\)。恰好没有买到,那么我们假装第一次买到第二次没买到,那么就是 \(\dfrac{n - i}{n}\times \dfrac{i + 1}{n}\)。
总而言之,如果我们买了 \(k\) 次,那么我们有 \(k - 1\) 次买到相同的,那么就是 \((\dfrac{i}{n})^{k - 1}\),还有一次我们买到不同的,因此是 \(\dfrac{n - i}{n}\),那么刚好买到一次不同的的概率是 \((\dfrac{i}{n})^{k - 1}\times \dfrac{n - i}{n}\)。
假设 \(k = \infty\) 则期望是 \(E = 1\times \dfrac{n - i}{n} + 2\times \dfrac{i}{n}\times \dfrac{n - i}{n} + 3\times (\dfrac{i}{n})^2\times \dfrac{n - i}{n} + \dots + k\times(\dfrac{i}{n})^{k - 1}\times \dfrac{n - i}{n}\)。虽然说理论上无穷大是不能随便加减乘除的但是反正我们是 OIer 不是 MOer┓( ´∀` )┏
两边同乘 \(\dfrac{i}{n}\),然后相减得到 \(E = 1 + \dfrac{i}{n} + (\dfrac{i}{n})^2 + \dots + (\dfrac{i}{n})^{k - 1} - k(\dfrac{i}{n})^k \dfrac{n - i}{n}\)。众所周知,一个大于 \(0\) 小于 \(1\) 的数字的无穷大次方无限趋于 \(0\) 因此我们可以把它看成 \(0\)(看度娘才知道的的),因此这个期望是个等差数列,\(E = \dfrac{n(1 - (\frac{i}{n})^{k - 1})}{n - i} = \dfrac{n}{n - i}\)。
因此 \(f_{i} = f_{i - 1} + E = f_{i - 1} + \dfrac{n}{n - i}\),很容易知道 \(f_n = \dfrac{n}{1} + \dfrac{n}{2} +\dots \dfrac{n}{n} = n(1 + \dfrac{1}{2} + \dots + \dfrac{1}{n})\)。
代码,这题输出确实是最难搞得,反正写起来蛮难受的说(悲
//SIXIANG
#include <iostream>
#define int long long
#define MAXN 100000
#define QWQ cout << "QWQ" << endl;
using namespace std;
int gcd(int n, int m) {
if(!m) return n;
else return gcd(m, n % m);
}
int divide(int x) {
int len = 0;
do {
len++;
x /= 10;
} while(x);
return len;
}
struct frac {
int mo, so;
};
frac add(frac A, frac B) {
int a = A.mo, b = A.so;
int c = B.mo, d = B.so;
frac ans; ans.mo = ans.so = 0;
ans.mo = a * d + c * b;
ans.so = b * d;
int G = gcd(ans.mo, ans.so);
ans.mo /= G, ans.so /= G;
return ans;
}
frac mul(frac A, int B) {
frac ans = A;
ans.mo *= B;
int G = gcd(ans.mo, ans.so);
ans.mo /= G, ans.so /= G;
return ans;
}
void print(frac f) {
int a = f.mo, b = f.so;
if(a % b == 0) {
cout << a / b << endl;
return ;
}
int ig = a / b, ss = a % b;
int il = divide(ig);//整数部分数位长度
int bl = max(divide(ss), divide(b));//横杠长度
for(int p = 1; p <= il; p++) cout << " ";
cout << ss << endl;
cout << ig;
for(int p = 1; p <= bl; p++) cout << "-";
cout << endl;
for(int p = 1; p <= il; p++) cout << " ";
cout << b << endl;
}
signed main() {
int n; cin >> n;
frac ans, now;
ans.mo = 1, ans.so = 1;
for(int p = 2; p <= n; p++) {
now.mo = 1, now.so = p;
ans = add(ans, now);
}
ans = mul(ans, n);
print(ans);
}
题解 [SHOI2002] 百事世界杯之旅的更多相关文章
- 洛谷 P1291 [SHOI2002]百事世界杯之旅 解题报告
P1291 [SHOI2002]百事世界杯之旅 题目描述 "--在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽 ...
- luogu P1291 [SHOI2002]百事世界杯之旅
题目链接 luogu P1291 [SHOI2002]百事世界杯之旅 题解 设\(f[k]\)表示还有\(k\)个球员没有收集到的概率 再买一瓶,买到的概率是\(k/n\),买不到的概率是\((n-k ...
- COGS 1224. [SHOI2002]百事世界杯之旅(期望概率)
COGS 1224. [SHOI2002]百事世界杯之旅 ★ 输入文件:pepsi.in 输出文件:pepsi.out 简单对比 时间限制:1 s 内存限制:128 MB [问题描述] ...
- P1291 [SHOI2002]百事世界杯之旅(概率)
P1291 [SHOI2002]百事世界杯之旅 设$f(n,k)$表示共n个名字,剩下k个名字未收集到,还需购买饮料的平均次数 则有: $f(n,k)=\frac{n-k}{n}*f(n,k) + \ ...
- 洛谷P1291 [SHOI2002]百事世界杯之旅 [数学期望]
题目传送门 百事世界杯之旅 题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听, ...
- P1291 [SHOI2002]百事世界杯之旅
题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶 ...
- [SHOI2002]百事世界杯之旅
题目:"--在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯. ...
- 洛谷P1291 [SHOI2002]百事世界杯之旅(期望DP)
题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶 ...
- [Luogu1291][SHOI2002]百事世界杯之旅
题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶 ...
- ●洛谷P1291 [SHOI2002]百事世界杯之旅
题链: https://www.luogu.org/recordnew/show/5861351题解: dp,期望 定义dp[i]表示还剩下i个盖子没收集时,期望还需要多少次才能手机完. 初始值:dp ...
随机推荐
- uniCloud云开发入门以及对传统开发方式的思考
事情缘由 作为选修了移动互联网应用的一员,老师讲的什么JS基础,还有ES6和uniapp,当然是没怎么听,因为是之前大二的时候都大概看过. 但是快到期末,老师讲了云开发,并且布置了与此相关的大作业,自 ...
- <七>理解多态
理解多态 多种多样的形态(静态多态,动态多态) 静态多态(编译时期) 1:函数重载 bool comparet(int ,int); bool compare(double,double); comp ...
- day27 CSS浮动、溢出 & js基本语法 & DOM文档流操作
接day26CSS=>CSS定位 overflow属性 值 描述 示例 visible 默认值,内容不会被修剪,会呈现在元素框之外 hidden 内容会被修剪,并且其余内容是不可见的 overf ...
- 各类数据库写入Webhsell总结
1.MySQL写入WebShell 1.1写入条件 数据库的当前用户为ROOT或拥有FILE权限: 知道网站目录的绝对路径: PHP的GPC参数为off状态: MySQL中的secure_file_p ...
- pyftpdlib中文乱码问题解决方案
python实现简易的FTP服务器 from pyftpdlib.authorizers import DummyAuthorizer from pyftpdlib.handlers import F ...
- 【Shell案例】【while循环、正则表达式、sed、awk、grep】5、打印空行的行号
描述写一个 bash脚本以输出一个文本文件 nowcoder.txt中空行的行号,可能连续,从1开始 示例:假设 nowcoder.txt 内容如下:ab c d e f 你的脚本应当输出:35791 ...
- Java工厂模式的最佳实践?
"Simplicity is prerequisite for reliability." - Edsger Dijkstra "简单是可靠的前提条件." -- ...
- 当 xxl-job 遇上 docker → 它晕了,但我不能乱!
开心一刻 某次住酒店,晚上十点多叫了个外卖 过了一阵儿,外卖到了 因为酒店电梯要刷卡,所以我下楼去接 到了电梯口看到个模样不错的妹纸 我:是你么? 妹纸愣了下:嗯! 于是拉上进电梯回房间,正准备开始呢 ...
- 微软跨平台maui开发chatgpt客户端
image 什么是maui .NET 多平台应用 UI (.NET MAUI) 是一个跨平台框架,用于使用 C# 和 XAML 创建本机移动(ios,andriod)和桌面(windows,mac)应 ...
- 【Java面试指北】反射(1) 初识反射
如果你被问到:什么是反射?为什么需要反射.以及反射的应用?你会如何回答呢? 本篇会带大家初识反射,了解反射概念和基本应用.反射的原理以及深入源码的探究将会在后面几篇介绍. 一.什么是反射? 要理解什么 ...