BZOJ 3029 守卫者的挑战

一开始搞了两个dp数组,分别记到第i盘,胜j盘,拿到k个碎片和背包大小>=k的概率,然后寻思着把它们乘起来?

后来发现好像是错的。。。。这个地方不能用乘法,这两件事情是相关的。(我瞎jb猜的。。。其实是样例没过)

然后发现只要一个数组就行了。。。。收益就是+a[i],-1,问最后收益>=0,胜场>=l的方案数。。。然后直接dp。

卡内存差评。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 201
using namespace std;
int n,x,l,k,a[maxn];
double p[maxn],dp[maxn][maxn][maxn<<1],ans=0;
int main()
{
    scanf("%d%d%d",&n,&l,&k);
    for (int i=1;i<=n;i++) {scanf("%d",&x);p[i]=x/100.0;}
    for (int i=1;i<=n;i++) scanf("%d",&a[i]);
    dp[0][0][k+200]=1.0;
    for (int i=0;i<n;i++)
        for (int j=0;j<=n;j++)
            for (int k=-n;k<=n;k++)
            {
                dp[i+1][j][k+200]+=dp[i][j][k+200]*(1-p[i+1]);
                int base=k+a[i+1]+200;base=min(base,n+200);base=max(base,-n+200);
                dp[i+1][j+1][base]+=dp[i][j][k+200]*p[i+1];
            }
    for (int i=l;i<=n;i++)
        for (int k=0;k<=n;k++)
            ans+=dp[n][i][k+200];
    printf("%.6lf\n",ans);
    return 0;
}
时间: 2024-08-04 18:25:32

BZOJ 3029 守卫者的挑战的相关文章

bzoj 3029 守卫者的挑战——概率期望dp+状态数思考

题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3029 先随便写了个dfs,记录"前 i 次.成功 j 次.容量-残片=k"的概率.因为是否可行只和"成功次数"还有"容量-残片个数"有关,和容量.残片具体数量无关.准备记忆化,但发现状态存不下. #include<iostream> #include<cstdio> #include<cstring> #

BZOJ 3029 守卫者的挑战 期望DP

题目大意:给定n个事件,第i个事件发生的概率为pi,收益为ai,初始收益为k,求n个事件之后发生的事件数>=l且收益>=0的概率 令f[i][j][k]表示第i个事件进行后已经发生了j个事件且当前受益为k的概率 MB破输入法打两行字错了十多遍 第三维好大- - 不会爆? 实际上第三维大于n就没有意义了 因为收益大于n时一定不会扣到负数 因此将第三维大于n的状态全都存到n上即可 时间复杂度O(n^3) 卡内存差评 #include <cstdio> #include <cstr

bzoj 3029: 守卫者的挑战【概率dp】

以后写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

【TYVJ1864】[Poetize I]守卫者的挑战 概率与期望

[TYVJ1864][Poetize I]守卫者的挑战 描述 打开了黑魔法师Vani的大门,队员们在迷宫般的路上漫无目的地搜寻着关押applepi的监狱的所在地.突然,眼前一道亮光闪过."我,Nizem,是黑魔法圣殿的守卫者.如果你能通过我的挑战,那么你可以带走黑魔法圣殿的地图--"瞬间,队员们被传送到了一个擂台上,最初身边有一个容量为K的包包. 擂台赛一共有N项挑战,各项挑战依次进行.第i项挑战有一个属性ai,如果ai>=0,表示这次挑战成功后可以再获得一个容量为ai的包包:如

TYVJ-P1864 守卫者的挑战 题解

P1864 [Poetize I]守卫者的挑战 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 打开了黑魔法师Vani的大门,队员们在迷宫般的路上漫无目的地搜寻着关押applepi的监狱的所在地.突然,眼前一道亮光闪过.“我,Nizem,是黑魔法圣殿的守卫者.如果你能通过我的挑战,那么你可以带走黑魔法圣殿的地图……”瞬间,队员们被传送到了一个擂台上,最初身边有一个容量为K的包包. 擂台赛一共有N项挑战,各项挑战依次进行.第i项挑战有一个属性ai,如果ai

守卫者的挑战:三维dp

守卫者的挑战 难度级别: C: 编程语言:不限:运行时间限制:1000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 打开了黑魔法师 Vani 的大门,队员们在迷宫般的路上漫无目的地搜寻着关押 applepi 的监狱的所在地.突然,眼前一道亮光闪过.“我,Nizem,是黑魔法圣殿的守卫者.如果你能通过我的挑战,那么你可以带走黑魔法圣殿的地图……”瞬间,队员们被传送到了一个擂台上,最初身边有一个容量为 K 的包包.擂台赛一共有 N 项挑战,各项挑战依次进行.第

守卫者的挑战

守卫者的挑战   试题描述 打开了黑魔法师 Vani 的大门,队员们在迷宫般的路上漫无目的地搜寻着关押 applepi 的监狱的所在地.突然,眼前一道亮光闪过.“我,Nizem,是黑魔法圣殿的守卫者.如果你能通过我的挑战,那么你可以带走黑魔法圣殿的地图……”瞬间,队员们被传送到了一个擂台上,最初身边有一个容量为 K 的包包.擂台赛一共有 N 项挑战,各项挑战依次进行.第 i 项挑战有一个属性 ai,如果 ai>=0,表示这次挑战成功后可以再获得一个容量为 ai 的包包:如果 ai=-1,则表示这

【BZOJ3029】守卫者的挑战 [期望DP]

守卫者的挑战 Time Limit: 2 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 打开了黑魔法师Vani的大门,队员们在迷宫般的路上漫无目的地搜寻着关押applepi的监狱的所在地.突然,眼前一道亮光闪过.“我,Nizem,是黑魔法圣殿的守卫者.如果你能通过我的挑战,那么你可以带走黑魔法圣殿的地图……”瞬间,队员们被传送到了一个擂台上,最初身边有一个容量为K的包包. 擂台赛一共有N项挑战,各项挑战依次进行.第i

TYVJ.1864.[Poetize I]守卫者的挑战(概率DP)

题目链接...无 题目: P1864 [Poetize I]守卫者的挑战 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 打开了黑魔法师Vani的大门,队员们在迷宫般的路上漫无目的地搜寻着关押applepi的监狱的所在地.突然,眼前一道亮光闪过. "我,Nizem,是黑魔法圣殿的守卫者.如果你能通过我的挑战,那么你可以带走黑魔法圣殿的地图--"瞬间,队员们被传送到了一个擂台上,最初身边有一 个容量为K的包包. 擂台赛一共有N项挑战,各项挑战依次