1709 钉子和小球 1999年NOI全国竞赛
时间限制: 2 s
空间限制: 128000 KB
题目等级 : 大师 Master
题解
查看运行结果
题目描述 Description
有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1)。每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且除了最左端和最右端的格子外每个格子都正对着最下面一排钉子的间隙。

让一个直径略小于d的小球中心正对着最上面的钉子在板上自由滚落,小球每碰到一个钉子都可能落向左边或右边(概率各1/2),且球的中心还会正对着下一颗将要碰上的钉子。例如图2就是小球一条可能的路径。

我们知道小球落在第i个格子中的概率pi=               ,其中i为格子的编号,从左至右依次为0,1,...,n。

现在的问题是计算拔掉某些钉子后,小球落在编号为m的格子中的概率pm。假定最下面一排钉子不会被拔掉。例如图3是某些钉子被拔掉后小球一条可能的路径。

输入描述 Input Description
第1行为整数n(2<=n<=50)和m(0<=m<=n)。以下n行依次为木板上从上至下n行钉子的信息,每行中‘*’表示钉子还在,‘.’表示钉子被拔去,注意在这n行中空格符可能出现在任何位置。

输出描述 Output Description
仅一行,是一个既约分数(0写成0/1),为小球落在编号为m的格子中的概pm。既约分数的定义:A/B是既约分数,当且仅当A、B为正整数且A和B没有大于1的公因子。

样例输入 Sample Input
5 2

*

* .

* * *

* . * *

* * * * *

样例输出 Sample Output
7/16

数据范围及提示 Data Size & Hint
分类标签 Tags 点此展开

题解

f[i][j]表示落到第i层第j列的小球的个数。

如果(i,j)位置是‘*’时,它落到下一层左边和右边的几率是一样的,

f[i+1][j]+=f[i][j],f[i+1][j+1]+=f[i][j];

如果(i,j)位置是‘.’时,它直接落到下下层,因此他本该落到4个位置的球全部落到下下层,

f[i+2][j+1]+=(f[i][j]*4);

落到空隙的全部小球数目q=f[n+1][j](j从1到n+1)

最后将m+1(由于题目中m是从0开始数第m位,因此+1)位置的小球数目和全部小球数目q约分化简得到答案。

#include<cstdio>
#include<iostream>
using namespace std;
long long f[60][60],k,q;
char s[60][60];
int n,m;
long long gcd(long long x,long long y)//辗转相除法,求最大公约数
{
if (x%y==0) return y;
else gcd(y,x%y);
}
int main()
{
cin>>n>>m;
f[1][1]=1;
for (int i=1;i<=n;i++)
for (int j=1;j<=i;j++)
{
cin>>s[i][j];
if (s[i][j]=='*')
{
f[i+1][j]+=f[i][j];
f[i+1][j+1]+=f[i][j];
}
else if (s[i][j]=='.')
f[i+2][j+1]+=(f[i][j]*4);
}
for (int i=1;i<=n+1;i++)
k+=f[n+1][i];
q=gcd(f[n+1][m+1],k);
cout<<f[n+1][m+1]/q<<"/"<<k/q; }

  

 附上一份wng的题解

 根据概率求解

f(i,j)表示落在第i行第j列位置的概率

如果(i,j)位置是’*’, f(i+1,j)+=f(i,j)/2; f(i+1,j+1)+=f(i,j)/2;

如果(i,j)位置是’.’, f(i+2,j+1)+=f(i,j);

初始值:f(1,1)=1/1

f(n+1,m+1)即为所求。

/*
多次Wa的原因:
1<<n,应该(long long)1<<n
*/
#include <cstdio>
#include <iostream>
using namespace std;
const int maxn=55;
int n,m;
long long f[maxn][maxn];
char ch;
long long gcd(long long x,long long y){
if(x%y==0) return y;
return gcd(y,x%y);
}
int main(){
scanf("%d%d",&n,&m);
f[1][1]=(long long)1<<n;
for(int row=1;row<=n;row++){
for(int col=1;col<=row;col++){
do scanf("%c",&ch);
while(ch!='*'&&ch!='.');
if(ch=='*'){
f[row+1][col]+=f[row][col]/2;
f[row+1][col+1]+=f[row][col]/2;
}else f[row+2][col+1]+=f[row][col];
}
}
long long xi=gcd(f[n+1][m+1],(long long)1<<n);
cout<<f[n+1][m+1]/xi<<"/"<<((long long)1<<n)/xi<<endl;
return 0;
}

  

codevs 1709 钉子和小球的更多相关文章

  1. bzoj千题计划189:bzoj1867: [Noi1999]钉子和小球

    http://www.lydsy.com/JudgeOnline/problem.php?id=1867 dp[i][j] 落到(i,j)的方案数 dp[i][j]=0.5*dp[i-1][j]   ...

  2. POJ-1189 钉子和小球(动态规划)

    钉子和小球 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 7452 Accepted: 2262 Description 有一个 ...

  3. 钉子和小球_DP

    Description 有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1).每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且除了最左端 ...

  4. [bzoj1867][Noi1999][钉子和小球] (动态规划)

    Description Input 第1行为整数n(2<=n<=50)和m(0<=m<=n).以下n行依次为木板上从上至下n行钉子的信息,每行中‘*’表示钉子还在,‘.’表示钉 ...

  5. [POJ1189][BZOJ1867][CODEVS1709]钉子和小球

    题目描述 Description 有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1).每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且 ...

  6. POJ1189钉子和小球(DP)

    对钉子DP,如果钉子存在DP[i+1][j]+=DP[i][j]; DP[i+1][j+1]+=DP[i][j]; 如果不存在DP[i+2][j+1]+=4*DP[i][j]; 见代码:(有一个比较坑 ...

  7. 2018.09.24 bzoj1867: [Noi1999]钉子和小球(概率dp)

    传送门 概率dp经典题. 如果当前位置(i,j)(i,j)(i,j)有钉子,那么掉到(i+1,j),(i+1,j+1)(i+1,j),(i+1,j+1)(i+1,j),(i+1,j+1)的概率都是1/ ...

  8. BZOJ 1867 [Noi1999]钉子和小球 DP

    想状态和钉子的位置如何匹配想了半天...后来发现不是一样的吗$qwq$ 思路:当然是$DP$啦 提交:>5次(以为无故$RE$,实则是先乘后除爆了$long\space long$) 题解: 若 ...

  9. 【OpenJudge 191】【POJ 1189】钉子和小球

    http://noi.openjudge.cn/ch0405/191/ http://poj.org/problem?id=1189 一开始忘了\(2^{50}\)没超long long差点写高精度Q ...

随机推荐

  1. O - Extended Traffic(判断负环)

    题意:有n个城市,每一个城市有一个拥挤度ai,从一个城市I到另一个城市J的时间为:(aJ-aI)^3,存在负环.问从第一个城市到达第k个城市所话的时间,如果不能到达,或者时间小于3输出?否则输出所花的 ...

  2. java 基础(匿名内部类)

    匿名内部类 特点:不对外公开,进行实现功能,继承类,继承抽象类,实现某个接口的匿名内部类,实现相应的方法 特别注意:匿名内部类,匿名指的是 ,new 关键字右边的那个对象--如继承,或是接口    { ...

  3. java參数传递机制浅析

    欢迎转载,转载请声明出处! ----------------------------------------- 前言: java语言中,參数的传递仅仅有一种机制.那就是值传递. 举例: 以下将通过几个 ...

  4. DateGridew导出Excel表+常见错误提示

    在敲机房收费系统的时候,显示数据的时候需要将DateGridew 中的数据导出进Excel表.DateGridew导出Excel表是比较常见的,当然导出Excel表有很多种方法,下面是个人认为比较容易 ...

  5. HDU4530:小Q系列故事——大笨钟

    Problem Description 饱尝情感苦恼的小Q本打算隐居一段时间,但仅仅在3月25号一天没有出现,就有很多朋友想念他,所以,他今天决定再出来一次,正式和大家做个告别. 小Q近来睡眠情况很差 ...

  6. [Ruby] Ruby Variable Scope

    Scope defines where in a program a variable is accessible. Ruby has four types of variable scope, lo ...

  7. [Angular 2] Exposing component properties to the template

    Showing you how you can expose properties on your Controller to access them using #refs inside of yo ...

  8. htaccess URL重写rewrite与重定向redirect(转)

    1. 将 .htm 页面映射到 .php 1 Options +FollowSymlinks 2 RewriteEngine on 3 RewriteRule ^(.*)\.htm$ $1.php [ ...

  9. EventBus 事件总线 原理

    原理 一句话描述:register会把当前类中匹配的方法,存入一个map,而post会根据实参去map查找进行反射调用 撇开专业术语,其实EventBus就是在内部[存储]了一堆onEvent开头的方 ...

  10. 从今天开始学习C#啦

    此博客为证,在下从今天开始学习C#,并把心得体会记录下来.