Skip to content

Latest commit

 

History

History
52 lines (34 loc) · 1.54 KB

File metadata and controls

52 lines (34 loc) · 1.54 KB

Reto #9: Alterna las luces

Fácil 🟢

Están encendiendo las luces de Navidad 🎄 en la ciudad y, como cada año, ¡hay que arreglarlas!

Las luces son de dos colores: 🔴 y 🟢 . Para que el efecto sea el adecuado, siempre deben estar alternadas. Es decir, si la primera luz es roja, la segunda debe ser verde, la tercera roja, la cuarta verde, etc.

Nos han pedido que escribamos una función adjustLights que, dado un array de strings con el color de cada luz (representados con los emojis 🔴 para el rojo y 🟢 para el verde), devuelva el número mínimo de luces que hay que cambiar para que estén los colores alternos.

adjustLights(['🟢', '🔴', '🟢', '🟢', '🟢'])
// -> 1 (cambias la cuarta luz a 🔴)

adjustLights(['🔴', '🔴', '🟢', '🟢', '🔴'])
// -> 2 (cambias la segunda luz a 🟢 y la tercera a 🔴)

adjustLights(['🟢', '🔴', '🟢', '🔴', '🟢'])
// -> 0 (ya están alternadas)

adjustLights(['🔴', '🔴', '🔴'])
// -> 1 (cambias la segunda luz a 🟢)

Solución propuesta

function adjustLights(lights) {
    function numChanges(lights){
        let s = lights[0] === '🟢' ? '🔴' : '🟢'   
        let cambios = 0

        for (let i = 1; i < lights.length ; i++) {
            if(s !== lights[i]) cambios++
            s = s === '🟢' ? '🔴' : '🟢'
        }

        return cambios
    }

    return Math.min(numChanges(lights),numChanges(lights.reverse()))
}

Puntos conseguidos: 340

  • 3015 ops/s
  • Complejidad cognitiva: 6