javascript

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.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Entradas recientes

Creador de credenciales web – Aplicación gratuita

Hoy te voy a presentar un creador de credenciales que acabo de programar y que…

1 semana hace

Desplegar PWA creada con Vue 3, Vite y SQLite3 en Apache

Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…

2 semanas hace

Arquitectura para wasm con Go, Vue 3, Pinia y Vite

En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…

2 semanas hace

Vue 3 y Vite: crear PWA (Progressive Web App)

En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…

2 semanas hace

Errores de Comlink y algunas soluciones

Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…

2 semanas hace

Esperar promesa para inicializar Store de Pinia con Vue 3

En este artículo te voy a enseñar cómo usar un "top level await" esperando a…

2 semanas hace

Esta web usa cookies.