2021-06-15 00:49:18 -07:00
---
id: 5900f47c1000cf542c50ff8e
2021-11-17 06:20:53 -08:00
title: 'Problema 270: Corte dos quadrados'
2021-06-15 00:49:18 -07:00
challengeType: 5
forumTopicId: 301920
dashedName: problem-270-cutting-squares
---
# --description--
2021-11-17 06:20:53 -08:00
Um pedaço de papel quadrado com dimensões inteiras $N× N$ é colocado com um canto na origem e dois de seus lados ao longo dos eixos $x$ e $y$. Depois, cortamos os quadrados respeitando as seguintes regras:
2021-06-15 00:49:18 -07:00
2021-11-17 06:20:53 -08:00
- Fazemos apenas cortes retos entre dois pontos que estejam em lados diferentes do quadrado e que tenham como coordenadas números inteiros.
- Dois cortes não podem se cruzar, mas vários cortes podem se encontrar no mesmo ponto das arestas.
- Prosseguimos até que não seja possível fazer mais cortes.
2021-06-15 00:49:18 -07:00
2021-11-17 06:20:53 -08:00
Contando quaisquer reflexões ou rotações distintas, chamamos de $C(N)$ o número de maneiras de cortar um quadrado $N× N$. Por exemplo, $C(1) = 2$ e $C(2) = 30$ (mostrados abaixo).
2021-06-15 00:49:18 -07:00
2021-11-17 06:20:53 -08:00
<img class="img-responsive center-block" alt="maneiras de cortar o quadrado 2x2, contando reflexões e rotações como distintas" src="https://cdn.freecodecamp.org/curriculum/project-euler/cutting-squares.gif" style="background-color: white; padding: 10px;" />
2021-06-15 00:49:18 -07:00
2021-11-17 06:20:53 -08:00
Qual é o $C(30)\bmod {10}^8$ ?
2021-06-15 00:49:18 -07:00
# --hints--
2021-11-17 06:20:53 -08:00
`cuttingSquares()` deve retornar `82282080` .
2021-06-15 00:49:18 -07:00
```js
2021-11-17 06:20:53 -08:00
assert.strictEqual(cuttingSquares(), 82282080);
2021-06-15 00:49:18 -07:00
```
# --seed--
## --seed-contents--
```js
2021-11-17 06:20:53 -08:00
function cuttingSquares() {
2021-06-15 00:49:18 -07:00
return true;
}
2021-11-17 06:20:53 -08:00
cuttingSquares();
2021-06-15 00:49:18 -07:00
```
# --solutions--
```js
// solution required
```