题意:A和B两个卡牌大师玩游戏,A有$n$张牌,B有$m$张牌,桌上有$1$张牌,这$n+m+1$张牌互不相同且A和B都知道这些牌里有什么牌(但他们互相不知道对方有什么牌,两个人也都不知道桌上的那张牌是哪张),游戏轮流进行,A先手,每轮可以①询问对方有没有某张牌,如果对方有,就要把它丢弃,否则表明自己没有这张牌②猜测桌上的牌,猜对了就赢,猜错了就输,问$A$和$B$获胜的概率(假设两人都磕了药足够聪明)

很棒的题啊!奇妙思路++

首先肯定只有在最后才会去猜测桌上的牌,因为要一发定输赢

假设这轮是A,下一轮是B,那么A可以去询问B有没有某张牌,这个询问有两种性质,可以是

①真询问,也就是随机询问对方有没有$m+1$张牌中的某一张

②假询问,也就是随机询问对方有没有自己$n$张牌中的某张牌

为什么要有假询问?因为这样做可以勾引B去猜桌上的牌,如果B猜错了,A自然就赢了

下面对A的询问真假性和B的反应分类讨论,设先手有$n$张牌,后手有$m$张牌时先手获胜的概率是$f\left(n,m\right)$

①A做真询问

如果问到B有的牌,那么B就知道A是在做真询问,局面就变成B扔掉一张牌并先手;此时A获胜的概率是$\dfrac{m}{m+1}\left(1-f\left(m-1,n\right)\right)$

如果恰好问到桌上那张牌:如果B认为A在做真询问,那么B就赢了;如果B认为A在做假询问,那么B之后就会认为桌上的牌不是这张,A就知道桌上的牌是这张,那么A就赢了,此时A获胜的概率应加上$\dfrac{1}{m+1}$

②A做假询问

如果B认为A是在做真询问,那么他就会猜错,A稳赢,获胜概率为$1$

如果B认为A是在做假询问,那么A和B都知道A有这张牌,和扔掉没有区别,所以局面相当于A扔掉一张牌后B先手,此时A获胜的概率为$1-f\left(m,n-1\right)$

假设A有$p$的概率选择真询问,有$1-p$的概率选择假询问,因为B会让A获胜的概率尽可能小,所以A的总获胜概率为

$\min\left\{\dfrac{pm}{m+1}\left(1-f\left(m-1,n\right)\right)+1-p,p\left(\dfrac{1}{m+1}+\dfrac{m}{m+1}\left(1-f\left(m-1,n\right)\right)\right)+\left(1-p\right)\left(1-f\left(m,n-1\right)\right)\right\}$

A要找到一个$p$使上面这个式子最大,如果把$p$作为自变量这其实就是两个一次函数取$\min$,一个单调递增一个单调递减,所以直接取交点即可

最后发现这其实是个DP,因为转移时下标比较鬼畜所以写成递归的形式会比较好

真是妙啊!

#include<stdio.h>
double p[1010][1010];
double du(int x){return x;}
void f(int n,int m){
	if(p[n][m]>0)return;
	if(n==0){
		p[0][m]=1/du(m+1);
		return;
	}
	if(m==0){
		p[n][0]=1;
		return;
	}
	f(m-1,n);
	f(m,n-1);
	double pr=p[m][n-1]/(p[m][n-1]+1/du(m+1));
	p[n][m]=pr*m/du(m+1)*(1-p[m-1][n])+1.-pr;
}
int main(){
	int n,m;
	scanf("%d%d",&n,&m);
	f(n,m);
	printf("%.9lf %.9lf",p[n][m],1.-p[n][m]);
}

[CF98E]Help Shrek and Donkey的更多相关文章

  1. [CF98E]Help Shrek and Donkey(纳什均衡)

    https://www.cnblogs.com/MashiroSky/p/6576398.html #include<cstdio> #include<algorithm> # ...

  2. 【Codeforces 98E】 Help Shrek and Donkey

    http://codeforces.com/problemset/problem/98/E (题目链接) 题意 A君有n张牌,B君有m张牌,桌上还有一张反扣着的牌,每张牌都不一样. 每个回合可以做两件 ...

  3. 【Codeforces 98E】 Help Shrek and Donkey 游戏策略神题

    from http://www.cnblogs.com/MashiroSky/p/6576398.html A君有n张牌,B君有m张牌,桌上还有一张反扣着的牌,每张牌都不一样. 每个回合可以做两件事中 ...

  4. hdu 4740 The Donkey of Gui Zhou bfs

    The Donkey of Gui Zhou Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproble ...

  5. The Donkey of Gui Zhou

    Problem Description There was no donkey in the province of Gui Zhou, China. A trouble maker shipped ...

  6. hdu 4740 The Donkey of Gui Zhou(dfs模拟好题)

    Problem Description There was no donkey ,) , the down-right cell ,N-) and the cell below the up-left ...

  7. hdu 4740 The Donkey of Gui Zhou

    1.扯犊子超多if else 判断的代码,华丽丽的TLE. #include<stdio.h> #include<string.h> #define N 1010 int ma ...

  8. hdu 4740 The Donkey of Gui Zhou(暴力搜索)

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=4740 [题意]: 森林里有一只驴和一只老虎,驴和老虎互相从来都没有见过,各自自己走过的地方不能走第二次 ...

  9. HDU 4740 The Donkey of Gui Zhou (模拟)

    由于一开始考虑的很不周到,找到很多bug.....越改越长,不忍直视. 不是写模拟的料...................... 反正撞墙或者碰到已经走过的点就会转向,转向后还碰到这两种情况就会傻站 ...

随机推荐

  1. MySQL使用笔记(四)数据的操作

    By francis_hao    Dec 14,2016 数据的操作包括插入数据记录.更新数据记录和删除数据记录. 插入数据记录 插入单条数据记录 field表示的字段名和value表示数据要一一对 ...

  2. ExtJS 4.1 TabPanel动态加载页面并执行脚本【转】

    ExtJS 4.1 TabPanel动态加载页面并执行脚本 按照官方示例,可以动态加载页面,可是脚本不执行,于是查SDK.google,发现scripts需要设置为true,于是设置该属性,整个代码如 ...

  3. 在linux环境下让java代码生效的步骤

    1.kill jboss 2.compile 3.deploy 4.bootstrap jboss.

  4. 停止ambari上服务的顺序

    Before performing any upgrades or uninstalling software, stop all of the Hadoop services in the foll ...

  5. 使用 FirewallD 构建动态防火墙

    使用 FirewallD 构建动态防火墙 FirewallD 提供了支持网络/防火墙区域(zone)定义网络链接以及接口安全等级的动态防火墙管理工具.它支持 IPv4, IPv6 防火墙设置以及以太网 ...

  6. ShareSDK入门指南:Android 10分钟快速集成

    ShareSDK 官方已提供Android 快速集成教程,以官方教程为参考,本文重点指导大家在集成中遇到的问题. Android 快速集成官方教程:http://wiki.mob.com/Androi ...

  7. Eclipse Jetty调试时无法保存js文件

    Jetty会使用内存映射文件来缓存静态文件,包括js,css文件. 在Windows下,使用内存映射文件会导致文件被锁定,所以当Jetty启动的时候无法在编辑器对js或者css文件进行编辑. 解决办法 ...

  8. 使用state模块部署lamp架构

    install_httpd: pkg.installed: - name: httpd httpd_running: service.running: - name: httpd - enable: ...

  9. POJ 3617 Best Cow Line (模拟)

    题目链接 Description FJ is about to take his N (1 ≤ N ≤ 2,000) cows to the annual"Farmer of the Yea ...

  10. 类似web风格的 Winform 分页控件

    背景 最近做一个Winform的小程序,需要用到分页,由于之前一直在用 TonyPagerForWinForm.dll ,但该库没有源代码,网上找的也不全面,索性就准备自己改造一个.在园子里翻了一下, ...