--- title: Heronian triangles id: 595b98f8b5a2245e243aa831 challengeType: 5 videoUrl: '' localeTitle: Triângulos Heronianos --- ## Description

A fórmula do herói para a área de um triângulo, dada a extensão de seus três lados a, b e c, é dada por:

$$ A = \ sqrt {s (sa) (sb) (sc)}, $$

onde s é metade do perímetro do triângulo; isso é,

$$ s = \ frac {a + b + c} {2}. $$

Os triângulos de Heronian são triângulos cujos lados e área são todos inteiros.

Um exemplo é o triângulo com os lados 3, 4 e 5 cuja área é 6 (e cujo perímetro é 12).

Note que qualquer triângulo cujos lados são todos um múltiplo inteiro de 3, 4, 5; como 6, 8, 10, também será um triângulo de Heroniano.

Definir um triângulo Heroniano Primitivo como um triângulo Heroniano onde o maior divisor comum

dos três lados é 1 (unidade).

Isso excluirá, por exemplo, o triângulo 6, 8, 10.

Tarefa:

Implemente uma função baseada na fórmula de Herói, que retorna os primeiros n th triângulos ordenados em uma matriz de matrizes.

## Instructions
## Tests
```yml tests: - text: heronianTriangle é uma função. testString: 'assert(typeof heronianTriangle === "function", "heronianTriangle is a function.");' - text: 'heronianTriangle() deve retornar [[3, 4, 5], [5, 5, 6], [5, 5, 8], [4, 13, 15], [5, 12, 13], [9, 10, 17], [3, 25, 26], [7, 15, 20], [10, 13, 13], [8, 15, 17]]' testString: 'assert.deepEqual(heronianTriangle(testCases[0]), res[0], "heronianTriangle() should return [[3, 4, 5], [5, 5, 6], [5, 5, 8], [4, 13, 15], [5, 12, 13], [9, 10, 17], [3, 25, 26], [7, 15, 20], [10, 13, 13], [8, 15, 17]]");' - text: 'heronianTriangle() deve retornar [[3, 4, 5], [5, 5, 6], [5, 5, 8], [4, 13, 15], [5, 12, 13], [9, 10, 17], [3, 25, 26], [7, 15, 20], [10, 13, 13], [8, 15, 17], [13, 13, 24], [6, 25, 29], [11, 13, 20], [5, 29, 30], [13, 14, 15]],' testString: 'assert.deepEqual(heronianTriangle(testCases[1]), res[1], "heronianTriangle() should return [[3, 4, 5], [5, 5, 6], [5, 5, 8], [4, 13, 15], [5, 12, 13], [9, 10, 17], [3, 25, 26], [7, 15, 20], [10, 13, 13], [8, 15, 17], [13, 13, 24], [6, 25, 29], [11, 13, 20], [5, 29, 30], [13, 14, 15]],");' - text: 'heronianTriangle() deve retornar [[3, 4, 5], [5, 5, 6], [5, 5, 8], [4, 13, 15], [5, 12, 13], [9, 10, 17], [3, 25, 26], [7, 15, 20], [10, 13, 13], [8, 15, 17], [13, 13, 24], [6, 25, 29], [11, 13, 20], [5, 29, 30], [13, 14, 15], [10, 17, 21], [7, 24, 25], [8, 29, 35], [12, 17, 25], [4, 51, 53]],' testString: 'assert.deepEqual(heronianTriangle(testCases[2]), res[2], "heronianTriangle() should return [[3, 4, 5], [5, 5, 6], [5, 5, 8], [4, 13, 15], [5, 12, 13], [9, 10, 17], [3, 25, 26], [7, 15, 20], [10, 13, 13], [8, 15, 17], [13, 13, 24], [6, 25, 29], [11, 13, 20], [5, 29, 30], [13, 14, 15], [10, 17, 21], [7, 24, 25], [8, 29, 35], [12, 17, 25], [4, 51, 53]],");' - text: 'heronianTriangle() deve retornar [[3, 4, 5], [5, 5, 6], [5, 5, 8], [4, 13, 15], [5, 12, 13], [9, 10, 17], [3, 25, 26], [7, 15, 20], [10, 13, 13], [8, 15, 17], [13, 13, 24], [6, 25, 29], [11, 13, 20], [5, 29, 30], [13, 14, 15], [10, 17, 21], [7, 24, 25], [8, 29, 35], [12, 17, 25], [4, 51, 53], [19, 20, 37],[16, 17, 17], [17, 17, 30], [16, 25, 39], [13, 20, 21]]' testString: 'assert.deepEqual(heronianTriangle(testCases[3]), res[3], "heronianTriangle() should return [[3, 4, 5], [5, 5, 6], [5, 5, 8], [4, 13, 15], [5, 12, 13], [9, 10, 17], [3, 25, 26], [7, 15, 20], [10, 13, 13], [8, 15, 17], [13, 13, 24], [6, 25, 29], [11, 13, 20], [5, 29, 30], [13, 14, 15], [10, 17, 21], [7, 24, 25], [8, 29, 35], [12, 17, 25], [4, 51, 53], [19, 20, 37],[16, 17, 17], [17, 17, 30], [16, 25, 39], [13, 20, 21]]");' ```
## Challenge Seed
```js // noprotect function heronianTriangle (n) { // Good luck! return []; } ```
### After Test
```js console.info('after the test'); ```
## Solution
```js // solution required ```