生日问题-N中至少有2个

时间:2018-10-24 05:57:35

标签: java birthday-paradox

我收到了一些修改过的生日问题- 我需要运行一个函数,该函数返回N个人中至少有两个共享同一生日的概率。然后一个 主函数,用于计算最小值n,以使该概率至少为0.5。 我试图写一个,但是唯一的输出是0或1,我很感谢调试或指出我做错了什么。 这是我所做的:

public class Birthday {

    public static double probSameBirthday(int n) {
        double days = 1 / 365;   // number of days
        int i, person = 0;       // total number of people
        double noProb = 0;
        int people = n;

        for (i = 2; i <= n; i = i + 1) {
            person = i;
            noProb = (1 - ( noProb * (1 - (person - 1) * days))) / 100;
        }

        return (noProb);        
    }

    public static void main(String[] args){
        int n = Integer.parseInt(args[0]);
        System.out.println(probSameBirthday(n));
    }
}

1 个答案:

答案 0 :(得分:2)

感谢以下评论: 将天更改为

double days = 1.0 / 365.0;

 the noProb =(1-( noProb * (1- (person-1)*days)))/100;

noProb =( noProb * (1- (person-1)*days));

,然后返回return (1-noProb); 它现在的运行方式与https://www.dcode.fr/birthday-problem

中的计算器相同