freeCodeCamp/curriculum/challenges/portuguese/10-coding-interview-prep/rosetta-code/generator-exponential.md

2.7 KiB

id title challengeType forumTopicId dashedName
5a23c84252665b21eecc7e7b Gerador/exponencial 5 302275 generatorexponential

--description--

Um gerador é uma entidade executável (como uma função ou procedimento) que contém um código que retorna uma sequência de valores, um de cada vez, para que a cada vez que você chame o gerador, o próximo valor na sequência seja fornecido.

Os geradores muitas vezes são criados a partir de co-rotinas ou objetos para que o estado interno do objeto seja tratado "naturalmente".

Os geradores são, frequentemente, usados em situações onde uma sequência é potencialmente infinita, e onde é possível construir o valor seguinte da sequência apenas com o estado mínimo.

--instructions--

Escreva uma função que use geradores para gerar quadrados e cubos. Crie um novo gerador que filtre todos os cubos do gerador de quadrados.

A função deve retornar o enésimo \( n^{th} \) valor do gerador filtrado.

Por exemplo, para \(n=7\), a função deve retornar 81, já que a sequência seria 4, 9, 16, 25, 36, 49, 81. Aqui, 64 é removido da sequência por ser um cubo.

--hints--

exponentialGenerator deve ser uma função.

assert(typeof exponentialGenerator == 'function');

exponentialGenerator() deve retornar um número.

assert(typeof exponentialGenerator(10) == 'number');

exponentialGenerator(10) deve retornar 144.

assert.equal(exponentialGenerator(10), 144);

exponentialGenerator(12) deve retornar 196.

assert.equal(exponentialGenerator(12), 196);

exponentialGenerator(14) deve retornar 256.

assert.equal(exponentialGenerator(14), 256);

exponentialGenerator(20) deve retornar 484.

assert.equal(exponentialGenerator(20), 484);

exponentialGenerator(25) deve retornar 784.

assert.equal(exponentialGenerator(25), 784);

--seed--

--seed-contents--

function exponentialGenerator(n) {

}

--solutions--

function exponentialGenerator(n){
  function* PowersGenerator(m) {
    var n=0;
    while(1) {
        yield Math.pow(n, m);
        n += 1;
    }
  }

  function* FilteredGenerator(g, f){
    var value = g.next().value;
    var filter = f.next().value;
    while(1) {
        if( value < filter ) {
            yield value;
            value = g.next().value;
        } else if ( value > filter ) {
            filter = f.next().value;
        } else {
            value = g.next().value;
            filter = f.next().value;
        }
    }
  }

  var squares = PowersGenerator(2);
  var cubes = PowersGenerator(3);

  var filtered = FilteredGenerator(squares, cubes);

  var curr=0;
  for(var i=0;i<n;i++) curr=filtered.next();

  return curr.value;
}