Resolviendo otro ejercicio de CodeWars me encontré uno en donde nos pide que hagamos una función que indique el elevador (izquierda o derecha) más cercano a un piso de un edificio. Dice más o menos así:
Existen 2 elevadores en un edificio, uno que está a la izquierda y otro a la derecha en un edificio que tiene 3 pisos (numerados del 0 al 2). Escribe una función que reciba el número de piso del elevador de la izquierda, el de la derecha y el piso en el que es llamado. Dicha función debe regresar el nombre del elevador que esté más cercano al piso en el que se llama. Si ambos están a la misma distancia entonces que regrese el de la derecha.
En resumen debería regresar “izquierda” o “derecha” dependiendo del elevador que esté más cercano al piso en donde se llama. Si la distancia es la misma, que regrese “derecha”.
Solución para el elevador más cercano
Recibimos 3 parámetros:
- La ubicación del elevador de la izquierda
- Ubicación del elevador de la derecha
- Número de piso en donde es llamado
Para calcular la distancia entre el elevador y el piso de llamada hacemos una resta así:
distancia = ubicacionDelElevador - pisoDeLlamada
Lo mismo para el otro elevador. De esta manera sabríamos cuál es la distancia y podríamos ver cuál es más pequeña. Ahora tenemos otro problema y es que la resta puede darnos números negativos y por lo tanto hacer que nuestra comparación sea errónea.
Este problema se soluciona calculando el valor absoluto.
Una vez que sabemos todo esto veamos el código.
Función en JavaScript
/**
* El elevador más cercano con JS
*
* @author parzibyte
*/
const elevadorMasCercano = (ubicacionDelIzquierdo, ubicacionDelDerecho, pisoDesdeDondeSeLlama) => {
// Calcular distancia
let distanciaIzquierda = Math.abs(pisoDesdeDondeSeLlama - ubicacionDelIzquierdo),
distanciaDerecha = Math.abs(pisoDesdeDondeSeLlama - ubicacionDelDerecho);
// Si está más cerca el izquierdo, regresamos "izquierda"
// y terminamos la ejecución de la función
if (distanciaIzquierda < distanciaDerecha) return "izquierda";
// Si las distancias son iguales o la derecha es más corta regresamos
// derecha
return "derecha";
}
// Probemos...
console.log(elevadorMasCercano(1, 2, 0)); // Debería ser izquierda
console.log(elevadorMasCercano(1, 1, 2)); // Debería ser derecha porque tienen la misma distancia
console.log(elevadorMasCercano(0, 2, 1)); // Debería ser derecha porque tienen la misma distancia
console.log(elevadorMasCercano(0, 2, 0)); // Debería ser izquierda
console.log(elevadorMasCercano(2, 1, 1)); // Debería ser derecha
Para obtener el valor absoluto usamos Math.abs. Después hacemos una comparación para saber si la distancia del elevador izquierdo es más corta que la del derecho, si es así significa que el de la izquierda está más cerca.
De otro modo, regresamos “derecha” ya sea porque es más cercano o porque ambas distancias son iguales.
Código ninja
Si quieres un código más simplificado puedes probar con este que usa el operador ternario:
/**
* El elevador más cercano con JS
*
* @author parzibyte
*/
const elevadorMasCercano = (ubicacionDelIzquierdo, ubicacionDelDerecho, pisoDesdeDondeSeLlama) =>
Math.abs(pisoDesdeDondeSeLlama - ubicacionDelIzquierdo) < Math.abs(pisoDesdeDondeSeLlama - ubicacionDelDerecho) ? "izquierda" : "derecha";
// Probemos...
console.log(elevadorMasCercano(1, 2, 0)); // Debería ser izquierda
console.log(elevadorMasCercano(1, 1, 2)); // Debería ser derecha porque tienen la misma distancia
console.log(elevadorMasCercano(0, 2, 1)); // Debería ser derecha porque tienen la misma distancia
console.log(elevadorMasCercano(0, 2, 0)); // Debería ser izquierda
console.log(elevadorMasCercano(2, 1, 1)); // Debería ser derecha
Es una forma de simplificar el if y ahorrar declaración de variables, aunque no lo recomiendo mucho.
Más ejercicios y posts
Puedes encontrar más ejercicios resueltos en mi blog, y también aprender más sobre JavaScript.