POJ-1189 钉子和小球(动态规划)
2015-12-20 22:32
375 查看
钉子和小球
Time Limit: 1000MS Memory Limit: 10000K
Total Submissions: 7452 Accepted: 2262
Description
有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1)。每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且除了最左端和最右端的格子外每个格子都正对着最下面一排钉子的间隙。
让一个直径略小于d的小球中心正对着最上面的钉子在板上自由滚落,小球每碰到一个钉子都可能落向左边或右边(概率各1/2),且球的中心还会正对着下一颗将要碰上的钉子。例如图2就是小球一条可能的路径。
我们知道小球落在第i个格子中的概率pi=pi=,其中i为格子的编号,从左至右依次为0,1,…,n。
现在的问题是计算拔掉某些钉子后,小球落在编号为m的格子中的概率pm。假定最下面一排钉子不会被拔掉。例如图3是某些钉子被拔掉后小球一条可能的路径。
Input
第1行为整数n(2 <= n <= 50)和m(0 <= m <= n)。以下n行依次为木板上从上至下n行钉子的信息,每行中’*’表示钉子还在,’.’表示钉子被拔去,注意在这n行中空格符可能出现在任何位置。
Output
仅一行,是一个既约分数(0写成0/1),为小球落在编号为m的格子中的概pm。既约分数的定义:A/B是既约分数,当且仅当A、B为正整数且A和B没有大于1的公因子。
Sample Input
5 2
*
* .
. * *
Sample Output
7/16
状态转移方程,如果当前点没有钉子,那么会直接下落,如果有钉子,下落到左边和右边是概率都是一半
if(p[i][j]==0)
dp[i+2][j+1]+=dp[i][j];
else
{
dp[i+1][j]+=dp[i][j]>>1;
dp[i+1][j+1]+=dp[i][j]>>1;
}
初始的dp[0][0]=1<
Time Limit: 1000MS Memory Limit: 10000K
Total Submissions: 7452 Accepted: 2262
Description
有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1)。每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且除了最左端和最右端的格子外每个格子都正对着最下面一排钉子的间隙。
让一个直径略小于d的小球中心正对着最上面的钉子在板上自由滚落,小球每碰到一个钉子都可能落向左边或右边(概率各1/2),且球的中心还会正对着下一颗将要碰上的钉子。例如图2就是小球一条可能的路径。
我们知道小球落在第i个格子中的概率pi=pi=,其中i为格子的编号,从左至右依次为0,1,…,n。
现在的问题是计算拔掉某些钉子后,小球落在编号为m的格子中的概率pm。假定最下面一排钉子不会被拔掉。例如图3是某些钉子被拔掉后小球一条可能的路径。
Input
第1行为整数n(2 <= n <= 50)和m(0 <= m <= n)。以下n行依次为木板上从上至下n行钉子的信息,每行中’*’表示钉子还在,’.’表示钉子被拔去,注意在这n行中空格符可能出现在任何位置。
Output
仅一行,是一个既约分数(0写成0/1),为小球落在编号为m的格子中的概pm。既约分数的定义:A/B是既约分数,当且仅当A、B为正整数且A和B没有大于1的公因子。
Sample Input
5 2
*
* .
. * *
Sample Output
7/16
状态转移方程,如果当前点没有钉子,那么会直接下落,如果有钉子,下落到左边和右边是概率都是一半
if(p[i][j]==0)
dp[i+2][j+1]+=dp[i][j];
else
{
dp[i+1][j]+=dp[i][j]>>1;
dp[i+1][j+1]+=dp[i][j]>>1;
}
初始的dp[0][0]=1<
#include <iostream> #include <string.h> #include <math.h> #include <algorithm> #include <stdlib.h> using namespace std; char a[59]; int p[55][55]; long long int dp[59][59]; int n,m; long long int ans1; long long int ans2; long long int gcd(long long int ans1,long long int ans2) { if(ans1==0) return ans2; return gcd(ans2%ans1,ans1); } int main() { while(scanf("%d%d",&n,&m)!=EOF) { ans1=0; ans2=0; for(int i=0;i<n;i++) { for(int j=0;j<=i;j++) { scanf("%s",a); if(a[0]=='*') p[i][j]=1; else p[i][j]=0; } } memset(dp,0,sizeof(dp)); dp[0][0]=1; for(int i=0;i<n;i++) { dp[0][0]<<=1; } for(int i=0;i<n;i++) { for(int j=0;j<=i;j++) { if(p[i][j]==0) dp[i+2][j+1]+=dp[i][j]; else { dp[i+1][j]+=dp[i][j]>>1; dp[i+1][j+1]+=dp[i][j]>>1; } } } ans2=dp [m]; for(int i=0;i<n+2;i++) ans1+=dp [i]; cout<<ans2/gcd(ans1,ans2)<<"/"<<ans1/gcd(ans1,ans2)<<endl; } return 0; }
相关文章推荐
- cocs2d初步
- PHP-注册时邮箱验证功能的实现
- POJ-1189 钉子和小球(动态规划)
- js oop 封装
- 解密你不知道的火车
- Android:Message、Handler、Message Queue与Looper
- 魔兽世界之二:装备(C++程序设计第5周)
- 【蓝桥第六周】奥运火炬登珠峰
- Learning Python ~Part1: Getting Started ~心得整理
- RxJava学习笔记
- iOS — Autolayout之Masonry解读
- js oop 继承
- eatwhatApp开发实战(五)
- python websocket学习使用
- Oracle数据库的开启与关闭
- ARC入门和使用
- 【数说·大数据圈】机器学习在生物大数据应用的一个例子 文/飞扬
- Pimpl idiom,前向声明(forward declaration)与#include头文件
- 数据结构之拓扑排序
- JS常用方法函数