Luogu_3239 [HNOI2015]亚瑟王

vim-markdown 真好用

这个题难了我一下午

第一道概率正而八经\(DP\),还是通过qbxt讲解才会做的。

发现Sengxian真是个dalao。讲的真是很清楚。代码也比较干净

做题心得:

1.概率和期望联系紧密。若无法直接计算期望,可是用期望的性质,将问题转化为算概率

2.若目标概率无法直接计算,可以通过计算过程中的某个步骤的概率,间接的计算出目标概率

若跟据局面进行状压\(DP\),时间复杂度成熟不起。

考虑优化状态。

发现,对于某一张牌,我们只要知道他用没有用过就行了。

所以一个很重要的操作就是定序。

我们只需要枚举某一张牌。在某一个局面中是否会被选中就可以了。

根据某一个局面出现的概率,便可计算出某一张牌在某个局面被选的概率,从而推出期望。

那么问题就是推出这个局面出现的概率。也就是过程中某个步骤的概率。

我们可以更改一下决策, 我们只需要枚举在某一个局面中。要么在剩余j轮(也就是当前局面)的时候被选中,要么在永远不会被选中

然后直接转移到决策下一张卡。

这样做, 我们可以避免同一张卡之间不同决策之间的互相影响, 又可以不丢失任何答案。


设\(f_{i,j}\)为前\(i\)张卡牌已经决策完了,还剩下\(j\)局可以进行

根据上面的说明,便可以写出状态转移方程

\(f_{i,j}=f_{i-1,j}*(1-p_i)^j+f_{i-1,j+1}*(1-(1-p_i)^{j+1})\)


#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <bitset> using std::bitset; const int maxn=101000;
const int MAX=100000;
const long long mod=1000000001;
const int log_2=17;
const int log_3=11; int n;
long long map[log_2][300];
int check[log_2][log_3];
int Log_2,Log_3;
int len[log_2];
int step[maxn],tot;
bitset<maxn>vis; void init()
{
for(int i=0;i<(1<<log_3);i++)
if((i&(i<<1))==0)
step[++tot]=i;
return ;
} double Log(int base,int val)
{
return log(val)/log(base);
} long long calc(int limte)
{
memset(map,0,sizeof(map));
memset(check,0,sizeof(check));
memset(len,0,sizeof(len));
int wide=0;
for(int &i=wide,pas1=limte;i<=Log_2&&pas1<=n;i++,pas1<<=1)
for(int j=0,pas2=pas1;j<=Log_3&&pas2<=n;j++,pas2*=3)
{
check[i][j]=pas2,len[i]|=(1<<j);
vis[pas2]=1;
}
wide-=1;
for(int i=1;step[i]<=len[0]&&i<=tot;i++)
map[0][i]=1;
for(int i=0;i<wide;i++)
for(int j=1;step[j]<=len[i]&&j<=tot;j++)
for(int k=1;step[k]<=len[i+1]&&k<=tot;k++)
if((step[j]&step[k])==0)
map[i+1][k]=(map[i][j]+map[i+1][k])%mod;
long long ans=0;
for(int i=0;step[i]<=len[wide];i++)
ans=(ans+map[wide][i])%mod;
return ans;
} int main()
{
init();
scanf("%d",&n);
Log_2=Log(2,n);Log_3=Log(3,n);
long long ans=1;
for(int i=1;i<=n;i++)
if(!vis[i])
ans=(ans*calc(i))%mod;
printf("%lld",ans);
}

Luogu_3239 [HNOI2015]亚瑟王的更多相关文章

  1. 【BZOJ4008】[HNOI2015]亚瑟王 期望

    [BZOJ4008][HNOI2015]亚瑟王 Description 小 K 不慎被 LL 邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑. 他决定,在脱坑之前,最后再来打一盘亚瑟王.既然是最 ...

  2. BZOJ 4008: [HNOI2015]亚瑟王( dp )

    dp(i, j)表示考虑了前i张牌, 然后还有j轮的概率. 考虑第i+1张牌: 发动的概率 : p = dp(i, j) * (1 - (1-p[i+1])^j) 没发动的概率 : dp(i, j) ...

  3. 【BZOJ4008】[HNOI2015]亚瑟王(动态规划)

    [BZOJ4008][HNOI2015]亚瑟王(动态规划) 题面 BZOJ 洛谷 题解 设\(f[i][j]\)表示前\(i\)张卡中有\(j\)张被触发的概率. 分两种情况转移,即当前这张是否被触发 ...

  4. [洛谷 P3239] [HNOI2015]亚瑟王

    [HNOI2015]亚瑟王 题目描述 小 K 不慎被 LL 邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑.他决定,在脱坑之前,最后再来打一盘亚瑟王.既然是最后一战,就一定要打得漂亮.众所周知, ...

  5. 4008: [HNOI2015]亚瑟王

    4008: [HNOI2015]亚瑟王 链接 分析: 根据期望的线性性,直接求出每张牌出现的概率,最后乘以攻击力就是答案. 每张牌出现的概率只与它前面的牌有关,与后面的没有关系,于是按顺序考虑每张牌. ...

  6. 【BZOJ4008】[HNOI2015]亚瑟王

    [BZOJ4008][HNOI2015]亚瑟王 题面 bzoj 洛谷 题解 由期望的线性性 可以知道,把所有牌打出的概率乘上它的伤害加起来就是答案 记第$i$张牌打出的概率为$fp[i]$ 则 $$ ...

  7. bzoj[HNOI2015]亚瑟王 - 递推与动规 - 概率与期望

    [bzoj4008][HNOI2015]亚瑟王 2015年4月22日3,2991 Description 小 K 不慎被 LL 邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑. 他决定,在脱坑之 ...

  8. 概率DP——BZOJ4008 [HNOI2015]亚瑟王

    [HNOI2015]亚瑟王 Description 小 K 不慎被 LL 邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑.他决定,在脱坑之前,最后再来打一盘亚瑟王.既然是最后一战,就一定要打得漂 ...

  9. Bzoj4008 [HNOI2015]亚瑟王

    Time Limit: 20 Sec  Memory Limit: 512 MBSec  Special Judge Submit: 1009  Solved: 605[Submit][Status] ...

随机推荐

  1. Java关闭钩子的应用 - Shutdown Hook

    背景 在开发中,遇到这种情况,多个线程同时工作,突然一个线程遇到了fetal的错误,需要立即终止程序,等人工排查解决了问题之后重新启动.但是这样会有一个问题,程序终止时,其他线程可能正在进行重要操作, ...

  2. C++学习笔记: 智能指针

    c++ 智能指针学习新的 class Simple { public: Simple() { number = param; std::cout << "Simple: &quo ...

  3. js延迟加载优化页面响应速度

    网页打开速度是衡量网站性能的一个极为重要的指标,今天就来说说如何通过JS延迟加载的方式提高页面响应速度: JS延迟加载的 含义:即等页面加载完成之后再加载 JavaScript 文件.作用:JS延迟加 ...

  4. input textarea监听鼠标粘贴

    发现一个问题,在input/textarea中如果是鼠标粘贴内容进去,发现判断不了value的改变,html代码如下: <!doctype html> <html> <h ...

  5. angular开发中的两大问题

    一.在我们的angular开发中,会请求数据但轮播图等...在请求过数据后他的事件和方法将不再执行: 看我们的解决方案一: app.controller("text",functi ...

  6. Heap memory compared to stack memory

  7. 安卓app开发-04- app运行的运行和调试

    app 运行的运行和调试 本篇介绍在 Android Studio 开发工具,运行调试设备:真机和虚拟机. 真机调试(USB 连接手机) 尽量使用真机进行调试,无论是调试效果和速度都比模拟器要好.使用 ...

  8. 一、ionic 图片轮播问题

    使用ion-slide可以实现图片轮播,但是如果在html中仅仅增加ion-slide是远远不够的,会出现两个问题:图片加载不出来和图片轮播至最后一个不轮播的问题 1.如何解决图片加载不出来的问题 i ...

  9. js变量作用域--变量提升

    1.JS作用域 在ES5中,js只有两种形式的作用域:全局作用域和函数作用域,在ES6中,新增了一个块级作用域(最近的大括号涵盖的范围),但是仅限于let方式申明的变量. 2.变量声明 var x; ...

  10. java笔记--ASCII编码认知和转换

    ASCII是基于拉丁字母的一套电脑编码系统,主要用于显示英语字符是当今最通用的单字节编码.包括128个字符. --如果朋友您想转载本文章请注明转载地址"http://www.cnblogs. ...