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 \frac{n-i}{n}\times 3+...+(\frac{i}{n})^{\infty}\times \frac{n-i}{n}\times{\infty}\)

\(\frac{i}{n}E=\frac{i}{n}\times \frac{n-i}{n}\times 1+(\frac{i}{n})^2\times \frac{n-i}{n}\times 2+...+(\frac{i}{n})^{\infty}\times \frac{n-i}{n}\times {\infty}\)

\(E=(\frac{i}{n})^0+(\frac{i}{n})^1+(\frac{i}{n})^2+....(1)\)

\(\frac{i}{n}E=(\frac{i}{n})^1+(\frac{i}{n})^2+....(2)\)

\((1)-(2)\;\; E=\frac{n}{n-i}\)

我们考虑\(f[i]\)表示已经买到了i个名字的期望次数

\(f[i+1]=f[i]+\frac{n}{n-i}\)

然后就可以递推了。

输出比较神奇,但是注意一点也不会出错的。

#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
#define MAXN 40
#define ll long long
using namespace std;
int n;
long long fv[MAXN],fn[MAXN];
inline ll gcd(ll x,ll y)
{
    if(!y) return x;
    else return gcd(y,x%y);
}
inline int solve(ll x)
{
    int cur_ans=0;
    while(x)
    {
        cur_ans++;
        x/=10;
    }
    return cur_ans;
}
int main()
{
    #ifndef ONLINE_JUDGE
    freopen("ce.in","r",stdin);
    #endif
    scanf("%d",&n);
    fv[1]=1,fn[1]=1;
    for(int i=1;i<n;i++)
    {
        fv[i+1]=fv[i]*(n-i)+fn[i]*n;
        fn[i+1]=fn[i]*(n-i);
        long long cur=gcd(fn[i+1],fv[i+1]);
        fn[i+1]/=cur,fv[i+1]/=cur;
    }
    ll cur=fv[n]/fn[n];
    if(fv[n]%fn[n]==0) cout<<cur<<endl;
    else
    {
        fv[n]-=cur*fn[n];
        int len1=solve(cur);
        for(int i=1;i<=len1;i++) printf(" ");
        printf("%lld\n",fv[n]);
        int len2=solve(max(fv[n],fn[n]));
        printf("%lld",cur);
        for(int i=1;i<=len2;i++) printf("-"); puts("");
        for(int i=1;i<=len1;i++) printf(" ");
        printf("%lld\n",fn[n]);
    }
    return 0;
}

原文地址:https://www.cnblogs.com/fengxunling/p/10884258.html

时间: 2024-07-30 05:20:19

SHOI2002 百事世界杯之旅的相关文章

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

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

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 [SHOI2002]百事世界杯之旅

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

●洛谷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(加一

[洛谷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

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 ret

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

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

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

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