1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
| public class EliminationGame {
public int lastRemaining(int n) { boolean left = true; int head = 1; int step = 1; int remain = n; while(remain !=1){ if (left || remain%2 == 1){ head = head + step;
} remain = remain/2; step = step * 2; left = !left; } return head; } }
|