zoukankan      html  css  js  c++  java
  • [题解]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);
    }
  • 相关阅读:
    8.8集训
    8.7集训
    8.6集训
    poj 2492
    埃氏筛法
    并查集板子
    2018级程序能力实训第二次上机考试
    网络流
    活动安排问题
    等价类
  • 原文地址:https://www.cnblogs.com/superminivan/p/11514359.html
Copyright © 2011-2022 走看看