时间限制:1 秒

内存限制:32 兆

特殊判题:否

提交:316

解决:29

题目描述:

把n个骰子扔在地上,所有骰子朝上一面的点数之和为S。输入n,打印出S的所有可能的值出现的概率。

输入:

输入包括一个整数N(1<=N<=1000),代表有N个骰子。

输出:

可能有多组测试数据,对于每组数据,

按照Sample Output的格式输出每一个可能出现的和S的概率。

样例输入:
1
2
样例输出:
1: 0.167
2: 0.167
3: 0.167
4: 0.167
5: 0.167
6: 0.167 2: 0.028
3: 0.056
4: 0.083
5: 0.111
6: 0.139
7: 0.167
8: 0.139
9: 0.111
10: 0.083
11: 0.056
12: 0.028

思路:

标准的动态规划题目,根据上一步状态推出下一步。

另外此题判题数据应该是错误的,比如别人能AC的程序输入4得到的结果是:

4: 0.002

5: 0.005

6: 0.009

7: 0.017

8: 0.028

9: 0.043

10: 0.062

11: 0.080

12: 0.096

13: 0.108

14: 0.113

15: 0.108

16: 0.096

17: 0.080

18: 0.062

19: 0.043

20: 0.027

21: 0.015

22: 0.008

23: 0.003

24: 0.001

4和24对应的概率不一样,这显然是是错误的。

下面分别给出能AC的代码和我的代码。

代码1(能AC的代码):

#include<stdio.h>

#include<string.h>

#include<math.h>

int main()

{

    int n,i,j,k;

    double a[2][6005],all;

    while(scanf("%d",&n)!=EOF)

    {

        memset(a,0,sizeof(a));

        a[1][1]=1;

        a[1][2]=1;

        a[1][3]=1;

        a[1][4]=1;

        a[1][5]=1;

        a[1][6]=1;

        for(i=2;i<=n;i++)

        {

            for(j=i*6;j>=i;j--)

            {

                a[i%2][j]=0;

                if(j-1>0)

                    a[i%2][j]+=a[(i+1)%2][j-1];

                if(j-2>0)

                    a[i%2][j]+=a[(i+1)%2][j-2];

                if(j-3>0)

                    a[i%2][j]+=a[(i+1)%2][j-3];

                if(j-4>0)

                    a[i%2][j]+=a[(i+1)%2][j-4];

                if(j-5>0)

                    a[i%2][j]+=a[(i+1)%2][j-5];

                if(j-6>0)

                    a[i%2][j]+=a[(i+1)%2][j-6];

            }

        }

        all=pow(6.0,n);

        for(i=n;i<=n*6;i++)

            printf("%d: %.3lf\n",i,a[n%2][i]/all);

        printf("\n");

    }

    return 0;

}

代码2(我的代码):

#include <stdio.h>

#define N 1000

int main(void)
{
int n, i, j, k;
double a[2][N*6]; while (scanf("%d", &n) != EOF)
{
a[0][0] = 1;
for(i=1; i<=n; i++)
{
for (j=i; j<=i*6; j++)
{
a[i&1][j] = 0;
for (k=j-1; k>=j-6; k--)
{
if (k>=i-1 && k<=(i-1)*6)
a[i&1][j] += a[(i-1)&1][k]/6;
}
if (i == n)
printf("%d: %.3lf\n", j, a[i&1][j]);
}
}
printf("\n");
} return 0;
}
/**************************************************************
Problem: 1255
User: liangrx06
Language: C
Result: Wrong Answer
****************************************************************/

九度OJ 1255:骰子点数概率 (递归、DP)的更多相关文章

  1. 九度OJ 1338:角斗士 (递归、DP)

    时间限制:3 秒 内存限制:32 兆 特殊判题:否 提交:213 解决:66 题目描述: 角斗士是古罗马奴隶社会的一种特殊身份的奴隶,他们的职责是在角斗场上进行殊死搏斗,为了人们提供野蛮的娱乐.他们的 ...

  2. 九度OJ 1073:杨辉三角形 (递归)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3780 解决:1631 题目描述: 输入n值,使用递归函数,求杨辉三角形中各个位置上的值. 输入: 一个大于等于2的整型数n 输出: 题目可 ...

  3. 九度OJ 1092:Fibonacci (递归)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:1923 解决:1378 题目描述: The Fibonacci Numbers{0,1,1,2,3,5,8,13,21,34,55...} ...

  4. 九度OJ 1112:拦截导弹 (DP、最长下降子序列)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3124 解决:1525 题目描述: 某国为了防御敌国的导弹袭击,开发出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能 ...

  5. 九度OJ 1131:合唱队形 (DP、最长上升下降序列)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:2865 解决:881 题目描述: N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学不交换位置就能排成合唱队形. ...

  6. 九度OJ 1086:最小花费 (DP)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3960 解决:819 题目描述: 在某条线路上有N个火车站,有三种距离的路程,L1,L2,L3,对应的价格为C1,C2,C3.其对应关系如下 ...

  7. 九度OJ 1101:计算表达式 (DP)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:4340 解决:1335 题目描述: 对于一个不存在括号的表达式进行计算 输入: 存在多种数据,每组数据一行,表达式不存在空格 输出: 输出结 ...

  8. 【九度OJ】题目1078:二叉树遍历 解题报告

    [九度OJ]题目1078:二叉树遍历 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1078 题目描述: 二叉树的前序.中序.后序遍历 ...

  9. 【九度OJ】题目1467:二叉排序树 解题报告

    [九度OJ]题目1467:二叉排序树 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1467 题目描述: 二叉排序树,也称为二叉查找树 ...

随机推荐

  1. account for 与led to和result in的区别

    account for sth:be the explanation of sth; explain the cause of sth 作某事物的解释; 解释某事物的原因:His illness ac ...

  2. HTML5 Canvas 动态勾画等速螺线

    等速螺线亦称阿基米德螺线,得名于公元前三世纪希腊数学家阿基米德.阿基米德螺线是一个点匀速离开一个固定点的同时又以固定的角速度绕该固定点转动而产生的轨迹.在此向这位古代最伟大的数学家致敬.用Canvus ...

  3. windows pip源

    首先在window的文件夹窗口输入 : %APPDATA% 然后在底下新建pip文件夹,然后到pip文件夹里面去新建个pip.ini,然后再里面输入内容 [global] timeout = 6000 ...

  4. PHP实现查看邮件是否被阅读

      <? //当你在发送邮件时,你或许很想知道该邮件是否被对方已阅读.这里有段非常有趣的代码片段能够显示对方IP地址记录阅读//的实际日期和时间. error_reporting(0); Hea ...

  5. Javascript中的回调函数和匿名函数的回调

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  6. js 元素Dom新建并插入页面createElement

    纯js var o = document.createElement('script'); o.type = 'text/template'; o.id = 'demo'; document.docu ...

  7. MySQL:ERROR 1067 (42000): Invalid default value for 'end_time'

    © 版权声明:本文为博主原创文章,转载请注明出处 1.错误截图 2.错误分析 表中的第一个TIMESTAMP列(如果未声明为NULL或显示DEFAULT或ON UPDATE子句)将自动分配DEFAUL ...

  8. 0x00 使用Ant 设置项目

    1. Ant 简介: Ant 是一款广泛使用的流行的开源构建工具,它用Java语言编写. 2.Ant官网: Ant官网:http://ant.apache.org/ 3.设置环境变量: 新建 Vari ...

  9. 在oracle11g中配置多个DataGuard物理备机

    >> from zhuhaiqing.info 主机配置 alter system set DB_UNIQUE_NAME='starboss' scope=spfile; alter sy ...

  10. 篇章三:[AngularJS] 使用AngularCSS動態載入CSS

    前言 使用AngularAMD動態載入Controller 使用AngularAMD動態載入Service 上列兩篇文章裡,介紹了如何如何使用AngularAMD來動態載入Controller與Ser ...