Domination(概率DP)
Domination
题目链接:https://odzkskevi.qnssl.com/9713ae1d3ff2cc043442f25e9a86814c?v=1531624384
Edward is the headmaster of Marjar University. He is enthusiastic about chess and often plays chess with his friends. What's more, he bought a large decorative chessboard with N rows and M columns.
Every day after work, Edward will place a chess piece on a random empty cell. A few days later, he found the chessboard was dominated by the chess pieces. That means there is at least one chess piece in every row. Also, there is at least one chess piece in every column.
"That's interesting!" Edward said. He wants to know the expectation number of days to make an empty chessboard of N × M dominated. Please write a program to help him.
Input
There are multiple test cases. The first line of input contains an integer Tindicating the number of test cases. For each test case:
There are only two integers N and M (1 <= N, M <= 50).
Output
For each test case, output the expectation number of days.
Any solution with a relative or absolute error of at most 10-8 will be accepted.
Sample Input
2
1 3
2 2
Sample Output
3.000000000000
2.666666666667 题意: 给出一个n*m的棋盘,问下棋下到每行每列均有一个棋的情况步数的期望值 思路: 这个数据虽然不大,但是搜索那些肯定是不行的,但是我们又要列出所有的情况,就只能用记忆化搜索,
期望值就是每个步数的概率乘以这个步数之和,所以我们要求出每个步数分别的概率是多少,在这里我们使用三维dp
dp[i][j][k] 代表的是k个棋已经占了i行j列,保证i行并且j列里面都会有一个棋
然后我们想下怎么推导呢想一下,我们每多下一个棋,有四种可能
第一种 多占了一列
第二种 多占了一行
第三种 下在对角线,占一行一列
第四种 下在了之前已经占过的行列上
就可以推导出式子dp[i][j][k]=dp[i][j-1][k-1]+dp[i-1][j][k-1]+dp[i-1][j-1][k-1]+dp[i][j][k-1];
这四种可能的和,但是我下棋的时候每个情况有多少个位置可以下,这里也要求下概率
占一行(意思是这个棋的列要下在之前占过的列的位置,因为要新占一行,所以选的行就是剩下没被占过的数量,然后再除以总的剩下可以下的位置)
其他的以此类推
然后dp数组就存的是概率,我们再去枚举那个占了整个棋盘的概率dp[n][m][i]*i即可
大佬博客:https://blog.csdn.net/cq_pf/article/details/48393897
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
double dp[][][*];
int n,m;
void solve()
{
memset(dp,,sizeof(dp));
dp[][][]=1.0;
for(int i=;i<=n;i++)//枚举行
{
for(int j=;j<=m;j++)//枚举列
{
for(int k=;k<=n*m;k++)//枚举下的棋子个数
{
if(i==n&&j==m)//下最后一个棋的时候没有既不占列也不占行的可能性
{
dp[i][j][k]=(dp[i][j-][k-]*(m-j+)*i)/(n*m-k+)+(dp[i-][j][k-]*(n-i+)*j)/(n*m-k+)+
(dp[i-][j-][k-]*(m-j+)*(n-i+))/(n*m-k+);
}
else{
dp[i][j][k]=(dp[i][j-][k-]*(m-j+)*i)/(n*m-k+)+(dp[i-][j][k-]*(n-i+)*j)/(n*m-k+)+
(dp[i-][j-][k-]*(m-j+)*(n-i+))/(n*m-k+)+(dp[i][j][k-]*(j*i-(k-)))/(n*m-k+);
}
}
}
}
double sum=;
for(int i=;i<=n*m;i++)//算期望值
{
sum+=dp[n][m][i]*i;
}
printf("%.12lf\n",sum);
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
solve();
}
}
Domination(概率DP)的更多相关文章
- ZOJ 3822 Domination 概率dp 难度:0
Domination Time Limit: 8 Seconds Memory Limit: 131072 KB Special Judge Edward is the headm ...
- zoj 3822 Domination 概率dp 2014牡丹江站D题
Domination Time Limit: 8 Seconds Memory Limit: 131072 KB Special Judge Edward is the headm ...
- zoj 3822 Domination (概率dp 天数期望)
题目链接 参考博客:http://blog.csdn.net/napoleon_acm/article/details/40020297 题意:给定n*m的空棋盘 每一次在上面选择一个空的位置放置一枚 ...
- ZOJ 3822 Domination(概率dp 牡丹江现场赛)
题目链接:problemId=5376">http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5376 Edward ...
- ZOJ 3822 Domination(概率dp)
一个n行m列的棋盘,每天可以放一个棋子,问要使得棋盘的每行每列都至少有一个棋子 需要的放棋子天数的期望. dp[i][j][k]表示用了k天棋子共能占领棋盘的i行j列的概率. 他的放置策略是,每放一次 ...
- zoj3822 Domination 概率dp --- 2014 ACM-ICPC Asia Mudanjiang Regional Contest
一个n行m列的棋盘,每次能够放一个棋子.问要使得棋盘的每行每列都至少有一个棋子 须要的放棋子次数的期望. dp[i][j][k]表示用了k个棋子共能占据棋盘的i行j列的概率. 那么对于每一颗棋子,在现 ...
- ZOJ3822 ACM-ICPC 2014 亚洲杯赛事现场牡丹江司D称号Domination 可能性DP
Domination Time Limit: 8 Seconds Memory Limit: 131072 KB Special Judge Edward is the headm ...
- zoj 3822(概率dp)
ZOJ Problem Set - 3822 Domination Time Limit: 8 Seconds Memory Limit: 131072 KB Special Ju ...
- Codeforces 28C [概率DP]
/* 大连热身D题 题意: 有n个人,m个浴室每个浴室有ai个喷头,每个人等概率得选择一个浴室. 每个浴室的人都在喷头前边排队,而且每个浴室内保证大家都尽可能均匀得在喷头后边排队. 求所有浴室中最长队 ...
随机推荐
- java,数字,字符,字符串之间的转化
首先,先看一道编程题目: A除以B (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 本题要求计算A/B ...
- android--------性能优化之Allocation Tracker
Allocation Tracker 能做什么? 追踪内存分配信息,按顺序排列,这样我们就能清晰看出来某一个操作的内存是如何一步一步分配出来的.比如在有内存抖动的可疑点,我们可以通过查看其内存分配轨迹 ...
- linux中用composer安装yii框架
我的服务器是安装的是lanmp环境 如果环境版本比较低的话,建议升级一下版本 升级版本命令:./lanmp.sh cus 全都选择最高的.完成之后: curl -sS https://getcompo ...
- nyoj-1250-exgcd
机器人 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 Dr. Kong 设计的机器人卡尔非常活泼,既能原地蹦,又能跳远.由于受软硬件设计所限,机器人卡尔只能定点跳远 ...
- MSMQ 事务性消息处理
二.事务性消息处理 事务我想大家对这个词应该都不会陌生,在操作数据库的时候经常都会用到事务,确保操作成功,要么全部完成(成功) ,要么全部不完成(失败).在MSMQ中利用事务性处理,可以确保事务中的消 ...
- Leetcode 120
class Solution { public: int minimumTotal(vector<vector<int>>& triangle) { ) ][]; tr ...
- Shiro集成web环境[Springboot]-基础使用
Shiro集成web环境[Springboot] 1.shiro官网查找依赖的jar,其中shiro-ehcache做授权缓存时使用,另外还需要导入ehcache的jar包 <dependenc ...
- CSS知识点(二)
七.CSS的继承性和层叠性 继承性 面向对象语言都会存在继承的概念,在面向对象语言中,继承的特点:继承了父类的属性和方法.那么我们现在主要研究css,css就是在设置属性的.不会牵扯到方法的层面. 继 ...
- MYSQL--服务器的安装
MYSQL--服务器的安装 学java已经好久了,但是还是没有学会安装数据库,这次重装系统后自己学了学,昨天晚上刚刚装好,卸载了,再装一次,就想着把它笔记下来.要不又忘了.. 1.删除你的服务.在cm ...
- 使用AJAX报406错误
使用AJAX报406错误,基本有一下两种情况: (1)90%的可能是没有添加jackson包: (2)10%的可能是请求的url后缀是*.html 在springmvc里面,如果请求的是*.html, ...