Skip to content

Latest commit

 

History

History
78 lines (57 loc) · 2.29 KB

README.md

File metadata and controls

78 lines (57 loc) · 2.29 KB

Reto #5: El CyberTruck de Santa

Medio 🟠

Santa 🎅 está probando su nuevo trineo eléctrico, el CyberReindeer, en una carretera del Polo Norte. La carretera se representa con una cadena de caracteres, donde:

  • . = Carretera
  • S = Trineo de Santa
  • * = Barrera abierta
  • | = Barrera cerrada

Ejemplo de carretera: S...|....|.....

Cada unidad de tiempo, el trineo avanza una posición a la derecha. Si encuentra una barrera cerrada, se detiene hasta que la barrera se abra. Si está abierta, la atraviesa directamente.

Todas las barreras empiezan cerradas, pero después de 5 unidades de tiempo, se abren todas para siempre.

Crea una función que simule el movimiento del trineo durante un tiempo dado y devuelva un array de cadenas representando el estado de la carretera en cada unidad de tiempo:

const road = 'S..|...|..'
const time = 10 // unidades de tiempo
const result = cyberReindeer(road, time)

/* -> result:
[
  'S..|...|..', // estado inicial
  '.S.|...|..', // avanza el trineo la carretera
  '..S|...|..', // avanza el trineo la carretera
  '..S|...|..', // el trineo para en la barrera
  '..S|...|..', // el trineo para en la barrera
  '...S...*..', // se abre la barrera, el trineo avanza
  '...*S..*..', // avanza el trineo la carretera
  '...*.S.*..', // avanza el trineo la carretera
  '...*..S*..', // avanza el trineo la carretera
  '...*...S..', // avanza por la barrera abierta
]
*/

El resultado es un array donde cada elemento muestra la carretera en cada unidad de tiempo.

Ten en cuenta que si el trineo está en la misma posición que una barrera, entonces toma su lugar en el array.

Los elfos se inspiraron en este reto de Code Wars.

Solución propuesta

function cyberReindeer(road, time) {
    
    let results = [road]
    let s = 0
    let lastChar = '.'
    for (let i = 0; i < time - 1 ; i++) {
        let tmp = results[i]
        
        if(i === 4) tmp = tmp.replaceAll('|','*')

        tmp = tmp.split('')
        if(tmp[s+1] === '.' || tmp[s+1] === '*'){
            [tmp[s],lastChar] = [lastChar,tmp[s+1]]
            tmp[s+1] = 'S'
            s++
        }

        results.push(tmp.join(''))
    }
    return results
}

Puntos conseguidos: 150

  • 1263 ops/s
  • Complejidad cognitiva: 5