1. 程式人生 > >bzoj 3029: 守衛者的挑戰【概率dp】

bzoj 3029: 守衛者的挑戰【概率dp】

滾動數組 ios ble \n 轉移 spa min print amp

以後寫dp還是向後轉移吧……寫的把前面加起來的版本怎麽也調不過去
首先註意,因為地圖碎片只占1體積,所以>n,<-n的體積是沒用的,所以就可以把體積降到n級別,然後用這場勝負像後轉移即可,滾動數組優化

#include<iostream>
#include<cstdio>
using namespace std;
const int N=405;
int n,l,m,a[N];
double p[N],f[2][N][N],ans;
int main()
{
    scanf("%d%d%d",&n,&l,&m);
    for(int i=1;i<=n;i++)
        scanf("%lf",&p[i]),p[i]/=100;
    for(int i=1;i<=n;i++)
        scanf("%d",&a[i]);
    f[0][0][min(m,n)+n]=1;
    for(int i=0;i<=n;i++)
    {
        for(int j=0;j<=i;j++)
            for(int k=-n;k<=n;k++)
                f[(i+1)&1][j][k+n]=0;
        for(int j=0;j<=i;j++)
            for(int k=-n;k<=n;k++)
                f[(i+1)&1][j][k+n]+=f[i&1][j][k+n]*(1.0-p[i]),f[(i+1)&1][j+1][min(k+a[i],n)+n]+=f[i&1][j][k+n]*p[i];
    }
    for(int j=l;j<=n;j++)
        for(int k=0;k<=n;k++)
            ans+=f[(n+1)&1][j][k+n];
    printf("%.6f\n",ans);
    return 0;
}

bzoj 3029: 守衛者的挑戰【概率dp】