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


题目描述 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 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

 

之前的一些废话:还有两天出国

题解:概率DP,f(i,j)表示到了第i行第j列的概率,首先f(1,1)=1,然后对于每一个钉子,各有50%的几率掉到左右两个块,转移为f(i+1,j+1)+=f(i,j)/2,f(i+1,j)+=f(i,j)/2,对于把钉子拆了的情况,可以理解成小球直接往下掉了两行,不进行往两边的转移。

比较坑爹的是,这题要输出既约分数,我刚开始写了一个分数的结构体,但是发现RE不断,后来用DP数组只存了分子,然后就A了。还有一个比较坑的是BZOJ不让输出回车,要不然presentation_error.

代码:

#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<queue>
#include<cstdio>
using namespace std;
typedef long long LL;
#define mem(a,b) memset(a,b,sizeof(a))
typedef pair<int,int> PII;
inline int read()
{
    int x=0,f=1;char c=getchar();
    while(!isdigit(c)){if(c==‘-‘)f=-1;c=getchar();}
    while(isdigit(c)){x=x*10+c-‘0‘;c=getchar();}
    return x*f;
}
LL gcd(LL a,LL b){return b==0ll ? a : gcd(b,a%b);}
int n,m,len[55];
LL dp[60][60];
char s[60];
bool pic[55][55];
int main()
{
    n=read();m=read();
    for(int i=1;i<=n;i++)for(int j=1;j<=i;j++)
    {
        scanf("%s",s);
        if(s[0]==‘*‘)pic[i][j]=1;
    }
    dp[1][1]=1;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=i;j++)
        {
            if(!pic[i][j] && i!=n){dp[i+2][j+1]=4ll*dp[i][j];continue;}
            dp[i+1][j]=dp[i+1][j]+dp[i][j];
            dp[i+1][j+1]=dp[i+1][j+1]+dp[i][j];
        }
    LL a=dp[n+1][m+1],b=1ll<<n,t=gcd(a,b);
    if(a==0)printf("0/1");
    else printf("%lld/%lld",a/t,b/t);
    return 0;
}

总结:不要轻易的打分数结构体。

时间: 2024-07-28 13:49:55

[POJ1189][BZOJ1867][CODEVS1709]钉子和小球的相关文章

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]   [(i-1,j)位置有钉子] + 0.5*dp[i-1][j-1]    [(i-1.j-1)位置有钉子] + dp[i-1][j-2]    [(i-1,j-2)位置没有钉子] #include<cstdio> #include<iostream> using namespace s

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

Description 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 Solut

bzoj1867: [Noi1999]钉子和小球(DP)

一眼题...输出分数格式才是这题的难点QAQ 学习了分数结构体... #include<iostream> #include<cstring> #include<cstdlib> #include<cstdio> #include<algorithm> #define ll long long using namespace std; const int maxn=60,inf=1e9; struct fra{ll u,d;fra(ll a=0,

codevs 1709 钉子和小球

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

POJ1189:钉子和小球(DP)

Description 有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1).每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且除了最左端和最右端的格子外每个格子都正对着最下面一排钉子的间隙. 让一个直径略小于d的小球中心正对着最上面的钉子在板上自由滚落,小球每碰到一个钉子都可能落向左边或右边(概率各1/2),且球的中心还会正对着下一颗将要碰上的钉子.例如图2就是小球一条可能的路径. 我们知道小球落在第i个格子中的概率pi=pi=,其

bzoj1867钉子和小球

题目链接 简单$DP$ $$dp[1][1]=1(\text{显然})$$ $$map[i][j]=='*'?dp[i+1][j]+=dp[i][j]/2,dp[i+1][j+1]+=dp[i][j]/2:dp[i+2][j+1]+=dp[i][j]$$ 如果直接输出概率这样就好, 但是让写成分数咋整? 开个结构体记录分子分母可以(好像大部分人这么做的) 本宝宝一开始开了两个数组分别记录, 但是人  萌  可爱 会出现各种  正义  玄学的事情, 反正开结构体的计算过程中没有爆$long\ lo

BZOJ 1867 NOI1999 钉子和小球 动态规划

题目大意:给定一个钉子阵,小球从最上方的钉子释放,求到达最底端某个位置的概率 只需要DP就好了 f[i][j]表示小球落在第i行第j个钉子上的概率 如果一个点有钉子 f[i+1][j]和f[i+1][j+1]平分这个点的概率 如果一个点没有钉子 f[i+2][j+1]得到这个点的全部概率 最后输出f[n+1][m+1]即可 注意不能输出回车 否则PE 无视这凶残的结构体操作符重载吧0.0 #include<cstdio> #include<cstring> #include<

poj 1189 钉子和小球

题目大意: 一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1).每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且除了最左端和最右端的格子外每个格子都正对着最下面一排钉子的间隙. 让一个直径略小于d的小球中心正对着最上面的钉子在板上自由滚落,小球每碰到一个钉子都可能落向左边或右边(概率各1/2),且球的中心还会正对着下一颗将要碰上的钉子.例如图2就是小球一条可能的路径. 现在的问题是计算拔掉某些钉子后,小球落在编号为m的格子中的概率p

钉子与小球

[题目描述] 有一个三角形木板,竖直立放,上面钉着n(n+1)/2颗钉子,还有(n+1)个格子(当n=5时如图1).每颗钉子和周围的钉子的距离都等于d,每个格子的宽度也都等于d,且除了最左端和最右端的格子外每个格子都正对着最下面一排钉子的间隙. 让一个直径略小于d的小球中心正对着最上面的钉子在板上自由滚落,小球每碰到一个钉子都可能落向左边或右边(概率各1/2),且球的中心还会正对着下一颗将要碰上的钉子.例如图2就是小球一条可能的路径. 现在的问题是计算拔掉某些钉子后,小球落在编号为m的格子中的概