题目描述
Problem
Figure 2. The probability of any outcome (leaf) in a probability tree diagram is given by the product of probabilities from the start of the tree to the outcome. For example, the probability that X is blue and Y is blue is equal to (2/5)(1/4), or 1/10.
Probability is the mathematical study of randomly occurring phenomena. We will model such a phenomenon with a random variable, which is simply a variable that can take a number of different distinct outcomes depending on the result of an underlying random process.
For example, say that we have a bag containing 3 red balls and 2 blue balls. If we let X X X represent the random variable corresponding to the color of a drawn ball, then the probability of each of the two outcomes is given by P r ( X = red ) = 3 5 \mathrm{Pr}(X = \textrm{red}) = \frac{3}{5} Pr(X=red)=53 and P r ( X = blue ) = 2 5 \mathrm{Pr}(X = \textrm{blue}) = \frac{2}{5} Pr(X=blue)=52.
Random variables can be combined to yield new random variables. Returning to the ball example, let Y Y Y model the color of a second ball drawn from the bag (without replacing the first ball). The probability of Y Y Y being red depends on whether the first ball was red or blue. To represent all outcomes of X X X and Y Y Y, we therefore use a probability tree diagram. This branching diagram represents all possible individual probabilities for X X X and Y Y Y, with outcomes at the endpoints (“leaves”) of the tree. The probability of any outcome is given by the product of probabilities along the path from the beginning of the tree; see Figure 2 for an illustrative example.
An event is simply a collection of outcomes. Because outcomes are distinct, the probability of an event can be written as the sum of the probabilities of its constituent outcomes. For our colored ball example, let A A A be the event " Y Y Y is blue." P r ( A ) \mathrm{Pr}(A) Pr(A) is equal to the sum of the probabilities of two different outcomes: P r ( X = blue and Y = blue ) + P r ( X = red and Y = blue ) \mathrm{Pr}(X = \textrm{blue and } Y = \textrm{blue}) + \mathrm{Pr}(X = \textrm{red and } Y = \textrm{blue}) Pr(X=blue and Y=blue)+Pr(X=red and Y=blue), or 3 10 + 1 10 = 2 5 \frac{3}{10} + \frac{1}{10} = \frac{2}{5} 103+101=52 (see Figure 2 above).
Given: Three positive integers k k k, m m m, and n n n, representing a population containing k + m + n k+m+n k+m+n organisms: k k k individuals are homozygous dominant for a factor, m m m are heterozygous, and n n n are homozygous recessive.
Return: The probability that two randomly selected mating organisms will produce an individual possessing a dominant allele (and thus displaying the dominant phenotype). Assume that any two organisms can mate.
Sample Dataset
2 2 2
Sample Output
0.78333
样例解释
2个显性纯合子AA,2个杂合子Aa,2个隐形纯合子aa
下一代中表现出隐性性状的只有aa,其概率为
p
(
a
a
)
=
1
−
C
2
2
+
1
4
C
2
2
+
1
2
C
2
1
C
2
1
C
6
2
=
13
60
p(aa) = 1 - {{C_2^2 + {1 \over 4} C_2^2 + {1 \over 2} C_2^1C_2^1} \over {C_6^2}} = {13 \over 60}
p(aa)=1−C62C22+41C22+21C21C21=6013
故表现出显性性状的概率为
p
=
1
−
13
60
=
47
60
=
0.78333
p = 1 - {13 \over 60} = {47 \over 60} = 0.78333
p=1−6013=6047=0.78333
题解
用1减去隐性表型概率计算最简单:
P
=
1
−
C
n
2
+
1
4
C
m
2
+
1
2
C
n
1
C
m
1
C
k
+
n
+
m
2
P = 1 - {{C_n^2 + {1 \over 4}C_m^2 + {1 \over 2}C_n^1C_m^1} \over {C_{k+n+m}^2}}
P=1−Ck+n+m2Cn2+41Cm2+21Cn1Cm1
参考代码
with open("rosalind_iprb.txt", "r") as f:
s = f.read().split()
k = float(s[0])
m = float(s[1])
n = float(s[2])
N = k + m + n
f.close()
p = 1 - (n * (n - 1) / 2 + 0.125 * m * (m - 1) + 0.5 * n * m) / (N * (N - 1) / 2)
print("%.5f" % p)