2018-09-30 22:01:58 +00:00
---
id: 5900f49f1000cf542c50ffb1
title: 'Problem 306: Paper-strip Game'
2020-11-27 18:02:05 +00:00
challengeType: 5
2019-08-05 16:17:33 +00:00
forumTopicId: 301960
2021-01-13 02:31:00 +00:00
dashedName: problem-306-paper-strip-game
2018-09-30 22:01:58 +00:00
---
2020-11-27 18:02:05 +00:00
# --description--
2018-09-30 22:01:58 +00:00
2020-11-27 18:02:05 +00:00
The following game is a classic example of Combinatorial Game Theory:
2018-09-30 22:01:58 +00:00
2021-07-21 15:59:56 +00:00
Two players start with a strip of $n$ white squares and they take alternate turns. On each turn, a player picks two contiguous white squares and paints them black. The first player who cannot make a move loses.
2018-09-30 22:01:58 +00:00
2021-07-21 15:59:56 +00:00
- $n = 1$: No valid moves, so the first player loses automatically.
- $n = 2$: Only one valid move, after which the second player loses.
- $n = 3$: Two valid moves, but both leave a situation where the second player loses.
- $n = 4$: There are three valid moves for the first player; who is able to win the game by painting the two middle squares.
- $n = 5$: Four valid moves for the first player (shown below in red); but no matter what the player does, the second player (blue) wins.
2018-09-30 22:01:58 +00:00
2021-07-21 15:59:56 +00:00
< img class = "img-responsive center-block" alt = "valid starting moves for strip with 5 squares" src = "https://cdn.freecodecamp.org/curriculum/project-euler/paper-strip-game.gif" style = "background-color: white; padding: 10px;" >
2018-09-30 22:01:58 +00:00
2021-07-21 15:59:56 +00:00
So, for $1 ≤ n ≤ 5$, there are 3 values of $n$ for which the first player can force a win.
Similarly, for $1 ≤ n ≤ 50$, there are 40 values of $n$ for which the first player can force a win.
For $1 ≤ n ≤ 1\\,000\\,000$, how many values of $n$ are there for which the first player can force a win?
2018-09-30 22:01:58 +00:00
2020-11-27 18:02:05 +00:00
# --hints--
2018-09-30 22:01:58 +00:00
2021-07-21 15:59:56 +00:00
`paperStripGame()` should return `852938` .
2018-09-30 22:01:58 +00:00
2020-11-27 18:02:05 +00:00
```js
2021-07-21 15:59:56 +00:00
assert.strictEqual(paperStripGame(), 852938);
2018-09-30 22:01:58 +00:00
```
2020-11-27 18:02:05 +00:00
# --seed--
2018-09-30 22:01:58 +00:00
2020-11-27 18:02:05 +00:00
## --seed-contents--
2018-09-30 22:01:58 +00:00
```js
2021-07-21 15:59:56 +00:00
function paperStripGame() {
2020-09-15 16:57:40 +00:00
2018-09-30 22:01:58 +00:00
return true;
}
2021-07-21 15:59:56 +00:00
paperStripGame();
2018-09-30 22:01:58 +00:00
```
2020-11-27 18:02:05 +00:00
# --solutions--
2018-09-30 22:01:58 +00:00
```js
// solution required
```