• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

265
Views
¿Cómo escribir una función que genere series de Fibonacci más pequeñas que un número dado (javascript)?

Aquí está mi código:

 function fibs(num) { //generate Fibonacci numbers: let arr = [1,1] let i = 2; function fibsRange(i) { arr[i] = arr[i-1] + arr[i-2] if (arr[i] < num) { fibsRange(i+1);//call function one more time; } return arr } return fibsRange(); } console.log(fibs(5));

Suponga que el número dado (num) es mayor que 2. ¿Dónde me equivoco?

Nota: edité mi código.

almost 3 years ago · Juan Pablo Isaza
3 answers
Answer question

0

primero: como lo mencionó Phil, su función (la primera) necesita devolver algo. segundo: no necesita 2 funciones, una hará el trabajo. Aquí hay una versión funcional de su código (también modifiqué un código innecesario.

Editar: agregué el caso cuando necesita analizar solo un parámetro

 function fibsRange(i,arr,num) { if(arr[i-1]+arr[i-2] > num) return arr else{ arr[i] = arr[i - 1] + arr[i - 2] return fibsRange(i + 1,arr,num); } } //in case you need just one parameter function fib(num){ let arr = [1, 1]; let i = 2; return fibsRange(i,arr,num); } //those(declaration of arr and i) are unnecessary in case you use fib let arr = [1, 1] let i = 2; console.log(fibsRange(i,arr,5)); console.log(fib(5));

almost 3 years ago · Juan Pablo Isaza Report

0

Nunca llamaste a tu función fibsRange() y nunca devolviste nada de fibs() .

La siguiente versión funciona.

 function fibs(num) { //generate Fibonacci numbers: let arr = [1, 1] if (num>1) fibsRange(2); function fibsRange(i) { arr[i] = arr[i - 1] + arr[i - 2] if (arr[i] < num) { fibsRange(i + 1); //call function one more time; } } return arr; } console.log(fibs(5)); //undified;

almost 3 years ago · Juan Pablo Isaza Report

0

Su código está comprobando si arr[i] < num , luego invoque fibsRange(i+1) . Esta es una lógica incorrecta, siempre obtendrá el número de fibbonacci un poco más alto que el num porque ya lo está configurando en arr[i] y luego verifica la condición. Sin embargo, primero debe verificar si arr[i] < num , y luego insertarlo en arr .

 function fibs(num) { //generate Fibonacci numbers: let arr = [1, 1]; let i = 2; function fibsRange(i) { const lastFibNumber = arr[i - 1] + arr[i - 2]; if (lastFibNumber < num) { arr.push(lastFibNumber); fibsRange(i + 1); //call function one more time; } return arr; } return fibsRange(i); } console.log(fibs(5));
almost 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error