DEV Community

Cristian Fernando
Cristian Fernando

Posted on • Updated on

Advent.js🎅🏼| #8: La locura de las criptomonedas

La locura de las criptomonedas

Invertir en criptomonedas es casi un deporte de riesgo. El otro día hackearon Bitmart y ha hecho que el valor de Bitcoin, y otras monedas, bajase un 25%.

Vamos a escribir una función que reciba la lista de precios de una criptomoneda en un día y debemos devolver la ganancia máxima que podríamos sacar si compramos y vendemos la inversión el mismo día.

La lista de precios es un array de números y representa el tiempo de izquierda a derecha. Por lo que ten en cuenta que no puedes comprar a un precio que esté a la derecha de la venta y no puedes vender a un precio que esté a la izquierda de la compra.

Por ejemplo:

const pricesBtc = [39, 18, 29, 25, 34, 32, 5]
maxProfit(pricesBtc) // -> 16 (compra a 18, vende a 34)

const pricesEth = [10, 20, 30, 40, 50, 60, 70]  
maxProfit(pricesEth) // -> 60 (compra a 10, vende a 70)
Enter fullscreen mode Exit fullscreen mode

Si ese día no se puede sacar ningún beneficio, tenemos que devolver -1 para evitar que hagamos una locura:

const pricesDoge = [18, 15, 12, 11, 9, 7]
maxProfit(pricesDoge) = // -> -1 (no hay ganancia posible)

const pricesAda = [3, 3, 3, 3, 3]
maxProfit(pricesAda) = // -> -1 (no hay ganancia posible)
Enter fullscreen mode Exit fullscreen mode

Mi solución:


Puedes seguir a @midudev y estar pendiente de los retos de Advent.js

Discussion (1)

Collapse
nahukas profile image
Nahuel Castro • Edited on

Hola Cristian te dejo mi solución!

  let difference = 0;
  for (let i = 0; i < prices.length; i++) {
    for (let j = i + 1; j < prices.length; j++) {
      if (prices[j] - prices[i] > difference) {
        difference = prices[j] - prices[i];
      }
    }
  }
  return difference !== 0 ? difference : -1;
Enter fullscreen mode Exit fullscreen mode