Files
2022-03-01 21:39:26 +05:30

59 lines
1.9 KiB
Markdown

---
id: 5900f4991000cf542c50ffab
title: 'Problema 301: Nim'
challengeType: 5
forumTopicId: 301955
dashedName: problem-301-nim
---
# --description--
Nim è un gioco giocato con pile di pietre, dove due giocatori si alternano a rimuovere qualsiasi numero di pietre da qualsiasi pila fino a quando non rimangono più pietre.
Considereremo la versione del gioco normale a tre pile di Nim, che funziona come segue:
- All'inizio del gioco ci sono tre cumuli di pietre.
- Al suo turno il giocatore rimuove qualsiasi numero positivo di pietre da qualsiasi mucchio singolo.
- Il primo giocatore non in grado di muovere (perché non ci sono pietre rimaste) perde.
Se ($n_1$, $n_2$, $n_3$) indica una posizione Nim consistente in cumuli di dimensione $n_1$, $n_2$ e $n_3$ c'è una funzione semplice $X(n_1,n_2, _3)$ — che si può cercare o tentare di dedurre da sé — che restituisce:
- zero se, con una strategia perfetta, il giocatore che sta per muovere alla fine perdere; o
- non zero se, con una strategia perfetta, il giocatore in procinto di muovere alla fine vincerà.
Per esempio $X(1, 2, 3) = 0$ perché, indipendentemente da ciò che fa il giocatore attuale, il suo avversario può rispondere con una mossa che lascia due cumuli di uguale dimensione, e a punto ogni mossa dal giocatore attuale può essere specchiata dal suo avversario fino a quando non rimangano pietre; così il giocatore attuale perde. Per illustrare:
- il giocatore corrente muove a (1,2,1)
- l'avversario muove a (1,0,1)
- il giocatore corrente muove a (0,0,1)
- l'avversario muove a (0,0,0), e così vince.
Per quanti interi positivi $n ≤ 2^{30}$ si ottiene $X(n, 2n, 3n) = 0$?
# --hints--
`nim()` dovrebbe restituire `2178309`.
```js
assert.strictEqual(nim(), 2178309);
```
# --seed--
## --seed-contents--
```js
function nim() {
return true;
}
nim();
```
# --solutions--
```js
// solution required
```