概率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]迷宫探险 ——动态规划的更多相关文章

  1. BZOJ 2246 [SDOI2011]迷宫探险 (记忆化搜索)

    题目大意:太长了,略 bzoj luogu 并没有想到三进制状压 题解: 3进制状压陷阱的状态,0表示这种陷阱的状态未知,1已知危险,2已知不危险 然后预处理出在当前状态下,每种陷阱有害的概率,设为$ ...

  2. BZOJ.2246.[SDOI2011]迷宫探险(DP 记忆化搜索 概率)

    题目链接 求最大的存活概率,DP+记忆化. 用f[s][x][y][hp]表示在s状态,(x,y)点,血量为hp时的存活概率. s是个三进制数,记录每个陷阱无害/有害/未知. 转移时比较容易,主要是在 ...

  3. 【BZOJ2246】[SDOI2011]迷宫探险(搜索,动态规划)

    [BZOJ2246][SDOI2011]迷宫探险(搜索,动态规划) 题面 BZOJ 洛谷 题解 乍一看似乎是可以求出每个东西是陷阱的概率,然而会发现前面走过的陷阱是不是陷阱实际上是会对当前状态产生影响 ...

  4. P2489 [SDOI2011]迷宫探险 概率dp

    LINK:迷宫探险 题目中要求在最优的策略下的最大概率 而并非期望概率. 一个坑点 题目中虽然没有明说 但是 探险者是知道地图的模样和每个陷阱的概率的. 所以才有最优策略一说. 最优策略尽管不知道可以 ...

  5. BZOJ2246 [SDOI2011]迷宫探险 【记忆化搜索dp + 概率】

    题目 输入格式 输出格式 仅包含一个数字,表示在执行最优策略时,人物活着走出迷宫的概率.四舍五入保留3位小数. 输入样例 4 3 3 2 .$. A#B A#C @@@ 143 37 335 85 9 ...

  6. BZOJ 2286: [Sdoi2011]消耗战 虚树 树形dp 动态规划 dfs序

    https://www.lydsy.com/JudgeOnline/problem.php?id=2286 wa了两次因为lca犯了zz错误 这道题如果不多次询问的话就是裸dp. 一棵树上多次询问,且 ...

  7. BZOJ 2243: [SDOI2011]染色 [树链剖分]

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6651  Solved: 2432[Submit][Status ...

  8. bzoj 3875 骑士游戏 - spfa - 动态规划

    Description  [故事背景] 长期的宅男生活中,JYY又挖掘出了一款RPG游戏.在这个游戏中JYY会 扮演一个英勇的骑士,用他手中的长剑去杀死入侵村庄的怪兽. [问题描述] 在这个游戏中,J ...

  9. bzoj 4033 树上染色 - 树形动态规划

    有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑 色,并将其他的N-K个点染成白色.将所有点染色后,你会获得黑点两两之间的距离加上白点两两之间距离的 ...

随机推荐

  1. 介绍hadoop的好文章

    http://www.centoscn.com/image-text/install/2014/1121/4158.html http://www.cnblogs.com/xia520pi/categ ...

  2. IOS7适配

    (1)如果应用程序始终隐藏 status bar 那么恭喜呢,你在UI上需要的改动很少很少. (2)如果应用程序显示status bar,可以讲status bar设置成黑色不透明 ,然后在UIVie ...

  3. MyBatis插入数据之后返回插入记录的id

    MyBatis插入数据的时候,返回该记录的id<insert id="insert" keyProperty="id" useGeneratedKeys= ...

  4. Java中枚举类型Enum的一种使用方式

    枚举类定义如下: public enum Status { SCUUESS("1", "成功"), FAILED("2", "失败 ...

  5. Django 表增加外键

    1.创建临时表,并把原表的数据复制到临时表 先根据python manage syl article查看创建临时表 CREATE TABLE `article_article_temp` ( `id` ...

  6. 图像处理框架 Core Image 介绍

    这篇文章会为初学者介绍一下 Core Image,一个 OS X 和 iOS 的图像处理框架. 如果你想跟着本文中的代码学习,你可以在 GitHub 上下载示例工程.示例工程是一个 iOS 应用程序, ...

  7. Pacman常用命令 文内搜索吧

    列出已经安装的软件包 https://wiki.archlinux.org/index.php/Pacman_(%E7%AE%80%E4%BD%93%E4%B8%AD%E6%96%87)  维基 pa ...

  8. ubuntu 16.04 安装node.js 8.x

    引自 https://www.digitalocean.com/community/tutorials/how-to-install-node-js-on-ubuntu-16-04#how-to-in ...

  9. javascript的offset、client、scroll使用方法

    offsetTop 指元素距离上方或上层控件的位置,整型,单位像素. offsetLeft 指元素距离左方或上层控件的位置,整型,单位像素. offsetWidth 指元素控件自身的宽度,整型,单位像 ...

  10. ES6变量解构赋值的用法

    一.数组赋值(从数组中提取值,按照对应位置,对变量赋值) 1. 完全解构(变量与值数目相等) let arr = [1, 2, 3]; let [a,b,c] = arr; console.log(a ...