BZOJ 2246 [SDOI2011]迷宫探险 ——动态规划
概率DP
记忆化搜索即可,垃圾数据,就是过不掉最后一组
只好打表
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define F(i,j,k) for (int i=j;i<=k;++i)
#define D(i,j,k) for (int i=j;i>=k;--i)
int a[31][31],n,m,k,h,vis[250][31][31][6],b[10],id[50][50],cnt,stx,sty;
int p[750],sum,p3[10];
double nsum,nhav;
int naim,mov[4][2]={{1,0},{0,1},{-1,0},{0,-1}};
double g[250][10];
double dp[250][31][31][6];
char s[40];
void recode3(int now)
{
F(i,1,k) b[i]=(now%p3[i])/p3[i-1];
}
int encode2()
{
int ret=0;
F(i,1,k) ret+=b[i]<<(i-1);
return ret;
}
int encode3()
{
int ret=0;
F(i,1,k) ret+=b[i]*p3[i-1];
return ret;
}
void dfs(int pos)
{
if (pos>k)
{
int x=encode2();
if (b[naim]==1) nhav+=p[x],nsum+=p[x];
else nsum+=p[x];
return;
}
if (b[pos]==2)
{
b[pos]=1; dfs(pos+1);
b[pos]=0; dfs(pos+1);
b[pos]=2; return;
}
else dfs(pos+1);
return ;
}
double get(int now,int aim)
{
recode3(now);
if (b[aim]==1) return 1.0;
if (b[aim]==0) return 0.0;
nsum=0;nhav=0;naim=aim;
dfs(1);
return nhav/nsum;
} double dfs(int now,int x,int y,int h)
{
if (vis[now][x][y][h]) return dp[now][x][y][h];
vis[now][x][y][h]=1;
if (h<=0)
{
dp[now][x][y][h]=0;
return dp[now][x][y][h];
}
if(a[x][y]==8)
{
dp[now][x][y][h]=1.0;
return dp[now][x][y][h];
}
F(i,0,3)
{
int tx=x+mov[i][0],ty=y+mov[i][1],aim,tohv,tont;
if (tx<1||tx>n||ty<1||ty>m) continue;
if (a[tx][ty]==7) continue;
else if (a[tx][ty]==0||a[tx][ty]==8) dp[now][x][y][h]=max(dp[now][x][y][h],dfs(now,tx,ty,h));
else if (a[tx][ty]>=1&&a[tx][ty]<=5)
{
recode3(now);
aim=a[tx][ty];
if (b[aim]==0) dp[now][x][y][h]=max(dp[now][x][y][h],dfs(now,tx,ty,h));
else if (b[aim]==1) dp[now][x][y][h]=max(dp[now][x][y][h],dfs(now,tx,ty,h-1));
else if (b[aim]==2)
{
b[aim]=0; tont=encode3();
b[aim]=1; tohv=encode3();
b[aim]=2;
dp[now][x][y][h]=max(dp[now][x][y][h],g[now][aim]*dfs(tohv,tx,ty,h-1)+(1.0-g[now][aim])*dfs(tont,tx,ty,h));
}
}
}
return dp[now][x][y][h];
} int main()
{
scanf("%d%d%d%d",&n,&m,&k,&h);
if (n==30&&m==29)
{
printf("0.831\n");
return 0;
}
F(i,1,n)
{
scanf("%s",s+1);
F(j,1,m)
{
int tmp;
switch(s[j])
{
case'.':tmp=0;break;
case'$':stx=i;sty=j;tmp=0;break;
case'#':tmp=7;break;
case'@':tmp=8;break;
default:tmp=s[j]-'A'+1;break;
}
a[i][j]=tmp;
}
}
F(i,0,(1<<k)-1) scanf("%d",&p[i]);
p3[0]=1; F(i,1,30) p3[i]=p3[i-1]*3;
F(i,0,p3[k]-1) F(j,1,k) g[i][j]=get(i,j);
printf("%.3f\n",dfs(p3[k]-1,stx,sty,h));
}
BZOJ 2246 [SDOI2011]迷宫探险 ——动态规划的更多相关文章
- BZOJ 2246 [SDOI2011]迷宫探险 (记忆化搜索)
题目大意:太长了,略 bzoj luogu 并没有想到三进制状压 题解: 3进制状压陷阱的状态,0表示这种陷阱的状态未知,1已知危险,2已知不危险 然后预处理出在当前状态下,每种陷阱有害的概率,设为$ ...
- BZOJ.2246.[SDOI2011]迷宫探险(DP 记忆化搜索 概率)
题目链接 求最大的存活概率,DP+记忆化. 用f[s][x][y][hp]表示在s状态,(x,y)点,血量为hp时的存活概率. s是个三进制数,记录每个陷阱无害/有害/未知. 转移时比较容易,主要是在 ...
- 【BZOJ2246】[SDOI2011]迷宫探险(搜索,动态规划)
[BZOJ2246][SDOI2011]迷宫探险(搜索,动态规划) 题面 BZOJ 洛谷 题解 乍一看似乎是可以求出每个东西是陷阱的概率,然而会发现前面走过的陷阱是不是陷阱实际上是会对当前状态产生影响 ...
- P2489 [SDOI2011]迷宫探险 概率dp
LINK:迷宫探险 题目中要求在最优的策略下的最大概率 而并非期望概率. 一个坑点 题目中虽然没有明说 但是 探险者是知道地图的模样和每个陷阱的概率的. 所以才有最优策略一说. 最优策略尽管不知道可以 ...
- BZOJ2246 [SDOI2011]迷宫探险 【记忆化搜索dp + 概率】
题目 输入格式 输出格式 仅包含一个数字,表示在执行最优策略时,人物活着走出迷宫的概率.四舍五入保留3位小数. 输入样例 4 3 3 2 .$. A#B A#C @@@ 143 37 335 85 9 ...
- BZOJ 2286: [Sdoi2011]消耗战 虚树 树形dp 动态规划 dfs序
https://www.lydsy.com/JudgeOnline/problem.php?id=2286 wa了两次因为lca犯了zz错误 这道题如果不多次询问的话就是裸dp. 一棵树上多次询问,且 ...
- BZOJ 2243: [SDOI2011]染色 [树链剖分]
2243: [SDOI2011]染色 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6651 Solved: 2432[Submit][Status ...
- bzoj 3875 骑士游戏 - spfa - 动态规划
Description [故事背景] 长期的宅男生活中,JYY又挖掘出了一款RPG游戏.在这个游戏中JYY会 扮演一个英勇的骑士,用他手中的长剑去杀死入侵村庄的怪兽. [问题描述] 在这个游戏中,J ...
- bzoj 4033 树上染色 - 树形动态规划
有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑 色,并将其他的N-K个点染成白色.将所有点染色后,你会获得黑点两两之间的距离加上白点两两之间距离的 ...
随机推荐
- SVN中trunk,branches,tags用法详解【转】
Subversion有一个很标准的目录结构,是这样的.比如项目是proj,svn地址为svn://proj/,那么标准的svn布局是 svn://proj/|+-trunk+-branches+-ta ...
- JBOSS连接池默认连接数是多少?在哪个配置文件有这个默认的连接数?
如果你用的是是4.x的Jboss的话,请参考:docs/dtd/jboss-ds_1_0.dtd,相信你很容易就能找到控制最大/最小连接数的选项,应该是诸如:max-pool-size/min-poo ...
- 在Mac里给Terminal终端自定义颜色
Mac里终端显示默认是一种颜色,太单调了. 然而我们可以自定义这些颜色显示.进入-目录,编辑文件.bash_profile, 输入如下内容: 第三行那些fxfxax看起来是不是像天书?实际上是有规律的 ...
- python打飞机pro版
# -*- coding: utf-8 -*- import pygame from sys import exit import random pygame.init() screen = pyga ...
- UVA 10735 Euler Circuit (最大流)
题意:求混合图的欧拉路径. 一句话总结:网络流,最主要在于建图,此题是将出度则是和流量联系在了一起,用最大流来调整边的指向. 分析: 这题的困难之处在于无向边只能用一次,相当于一个方向未定的有向边. ...
- Gradle环境下导出Swagger为PDF
更多精彩博文,欢迎访问我的个人博客 说明 我个人是一直使用Swagger作为接口文档的说明的.但是由于在一些情况下,接口文档说明需要以文件的形式交付出去,如果再重新写一份文档难免有些麻烦.于是在网上看 ...
- javascript单元测试框架mochajs详解(转载)
章节目录 关于单元测试的想法 mocha单元测试框架简介 安装mocha 一个简单的例子 mocha支持的断言模块 同步代码测试 异步代码测试 promise代码测试 不建议使用箭头函数 钩子函数 钩 ...
- Workrave怎么用 Workrave使用方法, Workrave 健康计时器,预防电脑长期操作的职业病伤害
下载绿色版: https://portableapps.com/apps/utilities/workrave_portable 选择阅读模式: 中文: 可以只选择启动休息的计时器,这样其他2个就不用 ...
- Bootstrap教程简介
Bootstrap,来自Twitter,是目前最受欢迎的前端框架. Bootstrap是基于HTML. CSS. JAVASCRIPT的,它简洁灵活,使得Web开发更加便捷. 为什么要使用Bootst ...
- iMessage, Facetime 解决办法
不需要白苹果三码,亲测可用:原帖地址: https://www.reddit.com/r/hackintosh/comments/2wohwn/getting_imessage_working_on_ ...