TopCoder problem "TopFive" used in SRM 243 (Division I Level Two)



Problem Statement

    You regularly participate in problem solving contests. During a contest all contestants must solve 3 problems, submitting their solutions to the judges for some points. After the competition, the judges will check the correctness of the problems, and award 0 points for incorrect problems.



You want to know your result as soon as possible and you hate waiting for the judges to finish their work. You are ambitious and you are only interested in knowing if you will finish among the top 5 people. Thus you decide to write your own program to determine your probability of getting a top 5 spot. Notice that if someone gets the same score as you, they will go above you on the top scorers list.



You will be given two String[]s - results, giving you the points all people have scored for their problems (prior to being judged), and accuracies, the submission accuracies for all people (the ith element of results corresponds to the ith element of accuracies). Each element of results and accuracies will contain three space-delimited integers without extra leading zeroes. For the ith contestant the corresponding element of results contains the points this contestant received for his three solutions, and the corresponding element of accuracies represents the probabilities in percents of these solutions to be correct.

Given the points you have (you think all your solutions are correct), return the probability you will make the top 5.
 

Definition

    
Class:TopFive
Method:findProbability
Parameters:String[], String[], int
Returns:double
Method signature:double findProbability(String[] results, String[] accuracies, int points)
(be sure your method is public)
    
 

Notes

-Your return value must have an absolute or relative error less than 1e-9.
 

Constraints

-results and accuracies will have the same number of elements.
-results will have between 1 and 50 elements, inclusive.
-Each element of results and accuracies will contain between 5 and 50 characters, inclusive.
-Each element of results will be formatted as "A B C", where A, B and C are integers between 0 and 1000, inclusive.
-Each element of accuracies will be formatted as "A B C", where A, B and C are integers between 0 and 100, inclusive.
-All integers in both results and accuracies will NOT contain any leading zeroes.
-points will be between 0 and 2000, inclusive.
 

Examples

0)
    
{"200 200 200",
"200 200 200",
"200 200 200",
"200 200 200",
"200 200 200"}
{"100 100 100",
"100 100 100",
"100 100 100",
"100 100 100",
"0 0 50"
}
100
Returns: 0.5
The first four people always solve their problems correctly (getting 600 points each) and finish higher than you. Your success depends on the fifth person, who has a 50-50 chance of solving the 3rd problem, and beating you.
1)
    
{"200 200 200",
"200 200 200",
"200 200 200",
"200 200 200",
"200 200 200"}
{"100 100 100",
"100 100 100",
"100 100 100",
"100 100 100",
"100 100 100"}
100
Returns: 0.0
Your performance isn't good enough for you to have any chance of making the top 5.
2)
    
{"928 209 594", "547 408 596", "190 865 494", "353 392 962", "6 252 267",
 "817 671 562", "631 78 290", "593 292 312", "59 51 286", "553 541 487",
 "466 318 271", "605 892 562", "596 261 63", "865 895 625", "893 479 586",
 "759 596 476", "157 407 819", "509 695 861", "696 730 430", "271 221 0",
 "922 296 640", "999 456 654", "320 550 805", "835 808 711", "9 161 670",
 "82 737 480", "939 12 363"}
{"84 87 72", "39 60 84", "56 78 48", "0 80 59", "11 69 94",
 "100 53 77", "87 77 55", "0 67 7", "89 63 3", "4 69 99", 
"58 9 49", "81 8 84", "81 85 55", "84 68 28", "7 1 46", 
"30 50 51", "16 82 8", "60 17 88", "44 30 67", "20 65 65", 
"40 75 73", "38 97 20", "82 38 88", "90 78 58", "58 30 66",
 "3 95 50", "76 60 57"}
1623
Returns: 0.8657569451352308
3)
    
{"200 200 200",
"200 200 200",
"200 200 200",
"200 200 200",
"600 600 600"}
{"100 100 100",
"100 100 100",
"100 100 100",
"100 100 100",
"75 75 75"
}
500
Returns: 0.015625
The fifth contestant must fail all his problems.
4)
    
{"200 200 200",
"200 200 200",
"200 200 200",
"200 200 200",
"33 33 33",
"33 200 200"}
{"100 0 0",
"0 0 100",
"0 100 0",
"100 100 100",
"100 100 100",
"33 80 50"
}
200
Returns: 0.10000000000000009
The last contestant must fail both the second and third problems to grant you a top 5 spot. The correctness of his first problem does not affect the result.

Problem url:

http://www.topcoder.com/stat?c=problem_statement&pm=4453

Problem stats url:

http://www.topcoder.com/tc?module=ProblemDetail&rd=7218&pm=4453

Writer:

Olexiy

Testers:

PabloGilberto , lbackstrom , brett1479

Problem categories:

Advanced Math, Brute Force, Simulation