• [题解]luogu_P2059_卡牌游戏(状态设计/概率dp


    需要设计一个不用记录哪个人死了的状态,其实人的编号在死人以后就和位置无关了,所以不如记录每个位置的概率

    设$f[i][j]$为共$i$个人,从第一个人做庄向后第$j$个人的概率,转移的话无非是看子问题,庄选某张牌杀掉人以后其实就只剩下$i-1$个人了,此时每个点的胜率加上对应位置的胜率即可,

    #include<bits/stdc++.h>
    using namespace std;
    const int maxn=59;
    int n,m,a[maxn];
    double f[maxn][maxn];
    int main(){
        scanf("%d%d",&n,&m);
        for(int i=1;i<=m;i++)scanf("%d",&a[i]);
        f[1][1]=1.0;
        for(int i=2;i<=n;i++){
            for(int k=1;k<=m;k++){
                int p=(a[k]%i==0)?i:a[k]%i;
                for(int j=1;j<=i-1;j++){
                    p++;
                    if(p>i)p=1;
                    f[i][p]+=f[i-1][j]/(1.0*m);
                }
            }
        }
        for(int i=1;i<=n;i++)
        printf("%.2lf%% ",f[n][i]*100.0);
    }
  • 相关阅读:
    Live2D 看板娘
    Live2D 看板娘
    Live2D 看板娘
    Live2D 看板娘
    Live2D 看板娘
    Live2D 看板娘
    Live2D 看板娘
    Live2D 看板娘
    教你搭建SpringSecurity3框架(附源码)
    浅谈数据库联合查询
  • 原文地址:https://www.cnblogs.com/superminivan/p/11514359.html
Copyright © 2020-2023  润新知