Problem 52323. Guess the number I'm thinking of (Part 2)
Have you tried the original "Guess the number I'm thinking of" (Problem 44630)?  This problem is just like that, except that the range of possible numbers can change, and pre-calculated answers are explicitly disallowed.  Computing all possible permutations on the fly is not disallowed per se, but it is discouraged due to the high computational load involved.  
In this game you are competing against two other people to guess the number that I'm thinking of.
- I randomly choose an integer between one and N (inclusive). N is an integer between 4 and 1000 (inclusive) that will be specified in each test as upperLimit. I don't provide any other clues about the number that is to be guessed.
- Your first opponent tries to guess the number. They guess randomly.
- Your second opponent tries to guess the number. They also guess randomly.
- You try to guess the number. But you guess strategically.
- The winner is the person who guesses my chosen number, or the person who guesses closest to my chosen number. This represents a "win".
- If two contestants are equally close, they may share the win, with such a result being declared a "draw". (It is a loss for the remaining contestant.) A draw is worth half as much as a win.
Each person hears the guesses stated by any preceding competitors, so you will be aware of the two prior guesses (provided to you as the vector guessesOfOpponents).  Moreover, each guess must be unique.
If everyone guessed randomly, each person should have an equal chance of winning.
It might seem that you're at a disadvantage, having the last opportunity to guess.  But actually you have the advantage of extra knowledge.
By guessing strategically, you should be able to achieve a "success rate" of substantially better than 33.3%.  The success rate is defined as follows.  
success rate = (wins + draws/2) / games
The precise value of the expected success rate (when guessing with the optimal strategy) depends upon the value of N:  when N = 4 you should be able to achieve a success rate of 17/48 ≈ 35.4% on average, increasing monotonically to above 50% for N ≥ 24, eventually approaching an asymptote of 19/36 ≈ 52.8%.  (See the Test Suite for details of the thresholds applied.) 
RELATED PROBLEM:  
Solution Stats
Problem Comments
Solution Comments
Show commentsProblem Recent Solvers4
Suggested Problems
- 
         Make the vector [1 2 3 4 5 6 7 8 9 10] 51851 Solvers 
- 
         Project Euler: Problem 8, Find largest product in a large string of numbers 1229 Solvers 
- 
         
         782 Solvers 
- 
         
         327 Solvers 
- 
         
         627 Solvers 
More from this Author32
Problem Tags
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!