Algoritmo en JavaScript: elevador más cercano

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:

  1. La ubicación del elevador de la izquierda
  2. Ubicación del elevador de la derecha
  3. 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.

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.

Dejar un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *