zoukankan      html  css  js  c++  java
  • 初学期望

    好吧,这是我第一次认真的搞期望有关的东西...

    先说一下期望的定义吧!期望等于所有可能的情况的(权值*概率)的和...

    其实在这部分我们只用注意这两个量怎么求解即可;

    针对这道题,我们需要求出在牌数为i时的情况数,因为权值与概率都很显然...

    显然有两个状态,有相同的牌,与没有相同的牌,所以我们需要用递推求解,对于计数类问题大部分是排列与组合的关系...

    之后就没了,这里需要尽可能的优化,记住(若q为a的逆元,则q2也是a2的逆元)...

    #include<bits/stdc++.h>
    #define ll long long
    using namespace std;
    const int N=10000100,mod=998244353;
    ll Q,f[N][2],n,ans,ss,s1;//f[i][0]表示到到第i个数时没选到的情况数,1表示选到... 
    inline int read()
    {
        int x=0,ff=1;
        char ch=getchar();
        while(!isdigit(ch)) {if(ch=='-') ff=-1;ch=getchar();}
        while(isdigit(ch)) {x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
        return x*ff; 
    }
    inline ll kuaisu(ll x,ll y)
    {
        ll ans=1;
        while(y)
        {
            if(y&1) ans=(ans*x)%mod;
            y>>=1;
            x=(x*x)%mod;
        }
        return ans;
    }
    inline void put(int x)
    {
        if(x<0) putchar('-'),x=-x;
        if(x>9) put(x/10);
        putchar(x%10+'0');
    } 
    int main()
    {
        //freopen("a.in","r",stdin);
        //freopen("a.out","w",stdout);
        Q=read();
        while(Q--)
        {
            n=read();
            if(n==1) {printf("2
    ");continue;}
            f[1][0]=n;ans=0;s1=kuaisu(n,mod-2);ss=s1;
            for(register int i=2;i<=n+1;++i)
            {
                f[i][0]=(f[i-1][0]*(n-i+1))%mod;
                f[i][1]=(f[i-1][0]*(i-1))%mod;ss=(ss*s1)%mod;
                ans=(ans+((f[i][1]*i)%mod*ss))%mod;
            }
            put(ans);puts("");
        }
        return 0;
    }

    做个小总结,对于这道题,因为许多的情况权值与概率都是相同的,所以我们需要讨论情况数.

    对于其他的题,就......

  • 相关阅读:
    Centos 7 安装shellcheck
    cunit环境搭建
    flex序列号和破解
    windows下python SSH-Client模块paramiko的安装与修改
    history优化设置
    shell配置和vim配置
    testlink 安装方法
    python解析GBK格式xml文件
    运用Loadrunner测试Mysql数据库性能 TRON•极客
    写python用到的一些大杀器
  • 原文地址:https://www.cnblogs.com/gcfer/p/11697727.html
Copyright © 2011-2022 走看看