zoukankan      html  css  js  c++  java
  • 北京信息科技大学第十一届程序设计竞赛G:kotori和抽卡(二)(排列组合)

    https://ac.nowcoder.com/acm/contest/940/G

    题目描述

    kotori最近喜欢上了lovelive这个游戏,因为她发现自己居然也是里面的一个人物。

    lovelive有个抽卡系统。共有R、SR、SSR、UR四个稀有度,每次单抽对应稀有度的概率分别是80%,15%,4%,1%。

    然而,kotori抽了很多次卡还没出一张UR,反而出了一大堆R,气得她想删游戏了。她想知道n次单抽正好出m张R卡的概率是多少?

    输入描述:

    两个正整数n和m(1<=m<=n<=50)

    输出描述:

    n次单抽正好出m张R的概率。保留四位小数。

    示例1

    输入

    复制

    1 1

    输出

    复制

    0.8000

    解题思路:

    公式:

    Cinom{m}{n}0.8^m*0.2^(n-m)

    #include <stdio.h>
    int main()
    {
    	double ans=1;
    	int n, m, i;
    	scanf("%d%d", &n, &m);
    	for(i=0; i<n-m; i++)
    		ans*=0.2;	
    	for(i=n; i>=n-m+1; i--)
    		ans*=i;
    	for(i=m; i>1; i--)
    		ans/=i;
    	for(i=0; i<m; i++)
    		ans*=0.8;	
    	
    	printf("%.4lf
    ", ans);
    	return 0;
    }

     为了防止溢出,最开始是写的下面一个代码,结果多此一举了。

    #include <stdio.h>
    int main()
    {
    	double ans=1;
    	int n, m, i;
    	scanf("%d%d", &n, &m);
    	if(m>n/2)
    	{
    		for(i=0; i<n-m; i++)
    			ans*=0.2;	
    	}
    	else
    	{
    		for(i=0; i<m; i++)
    			ans*=0.8;
    	}
    	for(i=n; i>=n-m+1; i--)
    		ans*=i;
    	for(i=m; i>1; i--)
    		ans/=i;
    	if(m>n/2)
    	{
    		for(i=0; i<m; i++)
    			ans*=0.8;	
    	}
    	else
    	{
    		for(i=0; i<n-m; i++)
    			ans*=0.2;
    	}
    	printf("%.4lf
    ", ans);
    	return 0;
    }
  • 相关阅读:
    Linux的JVM可以从SUN网站上下载
    实践是最好的老师
    SCAU 8624 多项式系数累加和
    SCAU 8617 阶乘数字和 (水题)
    SCAU 8614 素数
    SCAU 8619 公约公倍
    HDU ACM 1106 排序
    Uva 465 Overflow
    SCAU 8611 大牛之路I
    SCAU 9501 ACMer不得不知道的事儿
  • 原文地址:https://www.cnblogs.com/zyq1758043090/p/11852639.html
Copyright © 2011-2022 走看看