其实做这道题还蛮难受的。。。因为这个每一次有无限种可能我有钱我可以去买无限瓶可乐啊但是不是可口我不是很赞同┓( ´∀` )┏

然后参考了这篇题解发现错位相减这样的方法,让我们一起膜拜 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] 百事世界杯之旅的更多相关文章

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

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

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

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

  3. COGS 1224. [SHOI2002]百事世界杯之旅(期望概率)

    COGS 1224. [SHOI2002]百事世界杯之旅 ★   输入文件:pepsi.in   输出文件:pepsi.out   简单对比 时间限制:1 s   内存限制:128 MB [问题描述] ...

  4. P1291 [SHOI2002]百事世界杯之旅(概率)

    P1291 [SHOI2002]百事世界杯之旅 设$f(n,k)$表示共n个名字,剩下k个名字未收集到,还需购买饮料的平均次数 则有: $f(n,k)=\frac{n-k}{n}*f(n,k) + \ ...

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

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

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

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

  7. [SHOI2002]百事世界杯之旅

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

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

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

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

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

  10. ●洛谷P1291 [SHOI2002]百事世界杯之旅

    题链: https://www.luogu.org/recordnew/show/5861351题解: dp,期望 定义dp[i]表示还剩下i个盖子没收集时,期望还需要多少次才能手机完. 初始值:dp ...

随机推荐

  1. python模块/导入模块

    索引取值与迭代取值的差异 l1 = [1,2,3,4,5] 1.索引取值 可以任意位置任意次数的取值 不支持无序类型的数据取值 print(l1[3]) print(l1[3]) #可以直接获取任意位 ...

  2. TabControl控件的简单使用-添加tab

    1.首先创建一个MFC对话框框架,在对话框资源上从工具箱中添加上一个Tab Control 控件,根据需要修改一下属性,然后右击控件,为这个控件添加一个变量,将此控件跟一个CTabCtrl类变量绑定在 ...

  3. 一文速览 Dubbo 3.0

    本文将带你快速了解 Dubbo3 的设计背景.总体架构与核心特性.与典型用户如阿里巴巴 HSF2 的关系等.也可以通过如下部分了解更多: 小白用户,快速浏览 Dubbo3 核心特性: 下一代通信协议 ...

  4. 侦察工具——Httrack

    前言 web渗透学习笔记,实验环境为Metasploitable靶机上的DVWA.此随笔介绍Web渗透侦察工具Httrack Httrack 简介 Httrack能够克隆拷贝目标网站上的所有可访问.可 ...

  5. NW js 打包入门教程

    NW js 打包入门教程 NW.JS的安装与打包_u013288292的博客-CSDN博客_nwjs打包

  6. MySQL 字符串长度 char_length、length

    一.方法分类 二.具体方法 函数 描述 区别 char_length(str)或character_length(str) 返回字符串 str 的字符 1.单位为字符2.不管汉字还是数字或者是字母都算 ...

  7. day09-AOP-02

    AOP-02 4.问题提出 在上一篇的MyProxyProvider类中,我们的输出语句功能比较弱,在实际开发中,我们希望是以一个方法的形式,嵌入到真正执行的目标方法前,怎么办? 1.使用土方法解决 ...

  8. liunx系统安装Redis详细步骤

    liunx系统安装Redis详细步骤 官网下载Redis安装包 使用工具将redis安装包拖入liunx系统 创建Redis存放目录 mkdir /usr/local/redis 解压到redis存放 ...

  9. Python爬取cnnvd

    利用python监控CNNVD上面的新出漏洞实例,可以配合邮箱推送获取最新的漏洞情报 爬取cnnvd import requests from bs4 import BeautifulSoup imp ...

  10. css边框,盒子模型、浮动、定位

    边框,盒子模型.浮动.定位 一.边框 border-width : 边框宽度 border-style : 边框样式 1.solid 实线 2.none 无边框 3.dotted 点状虚线边框 4.d ...