SHOI 2002 百事世界杯之旅 | 概率论

题目:SHOI 2002

若当前已经有了 x 种,再买一个买到不一样的概率为 (n-x)/n,要使这个概率变成 1,则至少再买 n/(n-x) 瓶。

 1 #include <cstdio>
 2 #include <string>
 3
 4 long long max(long long x, long long y) {
 5     return y < x ? x : y;
 6 }
 7
 8 long long gcd(long long x, long long y) {
 9     return y ? gcd(y, x % y) : x;
10 }
11
12 int main() {
13     int n; scanf("%d", &n); long long x = 1, y = 1, t;
14     for (register int i = 2; i <= n; ++ i) {
15         t = y * i / gcd(y, i), x = t / y * x + t / i, y = t;
16     }
17     x *= n, t = gcd(x, y), x /= t, y /= t, t = x / y, x %= y;
18     if (x == 0) {
19         printf("%lld\n", t);
20     } else {
21         int a = 0, b = 0; long long r = t;
22         while (r) r /= 10, ++ a;
23         for (register int i = 1; i <= a; ++ i) putchar(‘ ‘);
24         printf("%lld\n%lld", x, t);
25         r = max(x, y);
26         while (r) r /= 10, ++ b;
27         for (register int i = 1; i <= b; ++ i) putchar(‘-‘);
28         puts("");
29         for (register int i = 1; i <= a; ++ i) putchar(‘ ‘);
30         printf("%lld\n", y);
31     }
32     return 0;
33 }

原文地址:https://www.cnblogs.com/milky-w/p/8479023.html

时间: 2024-11-02 23:22:47

SHOI 2002 百事世界杯之旅 | 概率论的相关文章

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

COGS 1224. [SHOI2002]百事世界杯之旅 ★   输入文件:pepsi.in   输出文件:pepsi.out   简单对比 时间限制:1 s   内存限制:128 MB [问题描述] “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶快行动!” 你关上电视,心想:假设有n个不同的球星名字,每个名字出现的概率相同,平均需要买几瓶饮料才能凑齐所

P1291 [SHOI2002]百事世界杯之旅

题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶快行动!” 你关上电视,心想:假设有n个不同的球星名字,每个名字出现的概率相同,平均需要买几瓶饮料才能凑齐所有的名字呢? 输入输出格式 输入格式: 整数n(2≤n≤33),表示不同球星名字的个数. 输出格式: 输出凑齐所有的名字平均需要买的饮料瓶数.如果是一个整数,则直接输出,否则应该直接按照分数格

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

题目链接 luogu P1291 [SHOI2002]百事世界杯之旅 题解 设\(f[k]\)表示还有\(k\)个球员没有收集到的概率 再买一瓶,买到的概率是\(k/n\),买不到的概率是\((n-k) /k\) 那么\(f[k] = f[k]*(n-k)/n + f[k-1]*k/n + 1\) 移向一下\(f[k] = f[k-1] + n/k\) 代码 #include<cstdio> #include<cstring> #include<algorithm> i

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

P1291 [SHOI2002]百事世界杯之旅 设$f(n,k)$表示共n个名字,剩下k个名字未收集到,还需购买饮料的平均次数 则有: $f(n,k)=\frac{n-k}{n}*f(n,k) + \frac{k}{n}*f(n,k+1) +1$ 移项整理,可得: $f(n,k)=f(n,k+1)+\frac{n}{k}$ 根据递推式,可得: $f(n,0)=n\sum_{k=1}^{n}\frac{1}{k}$ 蓝后gcd搞搞约分 注意输出 end. #include<iostream> #

[洛谷P1291]百事世界杯之旅

题目大意:有一种饮料,瓶盖上有n个球星的名字,买一瓶饮料出现每个名字的概率相同,求平均需要买几瓶饮料才能凑齐所有的名字. 解题思路:这是一道求数学期望的题目.设当前有$x$个名字,那么使名字变为$x+1$个名字平均需要买$n×\frac{1}{n-x}$瓶. 于是要求的就是$n(\frac{1}{1}+\frac{1}{2}+\frac{1}{3}+...+\frac{1}{n})$. 然后就是奇怪的输出了. C++ Code: #include<cstdio> #include<cma

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

题链: https://www.luogu.org/recordnew/show/5861351题解: dp,期望 定义dp[i]表示还剩下i个盖子没收集时,期望还需要多少次才能手机完. 初始值:dp[0]=0 显然对于一个状态,我们随机得到一个盖子,有两种可能: 1.得到了曾经没有的盖子,概率为i/N,并转移到dp[i-1]. 2.得到了已经有了的盖子,概率为(N-i)/N,并转移到dp[i]. 所以dp转移式: dp[i]=(i/n)*dp[i-1]+((N-i)/i)*dp[i]+1(加一

SHOI2002 百事世界杯之旅

题目链接:戳我 看到期望,想着不要从前转移. 一次后能买到不同种类的概率为\(\frac{n-i}{n}\) 两次后能买到不同种类的概率为\(\frac{i}{n}\times \frac{n-i}{n}\) n次后能买到不同种类的概率为\((\frac{i}{n})^n\times \frac{n-i}{n}\) 设总期望为\(E=\frac{n-i}{n}\times1+\frac{i}{n}\times \frac{n-i}{n}\times 2+(\frac{i}{n})^2\times

意大利的世界杯之旅结束了,你的编程之路才刚刚开始……

意大利无缘2018年俄罗斯世界杯!!! 上一次意大利无缘世界杯是什么时候???遥远的1958年!!! 整整60年,蓝色的意大利战袍从来没有过不出现在世界杯赛场上的时刻…… 对于很多的70后.80后.90后来说,意大利伴随着我们走过青春.走向中年,而现在,意大利的青春逝去了…… 而我们则要迎接即将到来的人工智能时代!!!拿什么迎接,用什么迎接,靠什么迎接…… 当然是编程!!! 几乎所有的大佬都在提人工智能,提AI,比尔盖茨.李彦宏.李开复等等  等等…… 我们能做点什么呢?我们可以做的太多了,但最

某县百姓百事110便民服务管理系统(1)——项目总结

项目总结 我是研二的一名学生,一直学习嵌入式方面的知识,C语言用的最多.以前本人未接触过web开发,这是第一次进行web开发,也是第一次学习.学习时间也就一个星期,看了<java编程思想>.<Servlet与JSP核心编程>.<http协议详解>,还未学习设计模式.框架方面的知识,关于js.css,随用随查就可以了. 因为我实习的公司是做国产芯片的,这个项目只是个试点项目(当然也是某县的真实应用系统),为了测试公司刚设计的服务器的性能.而且,经过测试,在应用框架的应用系