Introducción

No sé por qué pero hoy estaba recordando mis inicios en esto de la programación y vino a mi mente una ocasión en la que tuve que sacar el mayor de 3 números en el lenguaje de programación C.

Recuerdo que hice un montón de estructuras de control if, comparando el número 1 con el 2, luego el 1 con el 3, y así sucesivamente; cuando en realidad se puede resolver de una forma más elegante.

Mayor de 3 números en C

Nota: como vamos a ver arreglos, recomiendo que veas: Arreglos en C

Lo que vamos a utilizar es un arreglo de longitud fija. Es decir, un arreglo de 3. Y vamos a pedir los números por pantalla.

Más tarde recorremos ese arreglo y comparamos el número actual por el mayor hasta el momento.

#include <stdio.h>

int main(int argc, char const *argv[])
{
 // Aquí almacenaremos los 3 números
 int numeros[3];

 for (int i = 0; i < 3; ++i)
 {
  printf("Por favor, ingresa el numero %d:\n", i + 1); // Sumar 1 porque empezamos desde 0
  scanf("%d", &numeros[i]);
 }

 //Suponemos que el mayor es el primer número
 int numeroMayor = numeros[0];

 // Comenzar desde el 1, porque estamos suponiendo que el 0 es el mayor
 for (int indice = 1; indice < 3; ++indice)
 {
  int numeroActual = numeros[indice];
  if (numeroActual > numeroMayor){  
   // Cambiar únicamente si el actual es mayor que numeroMayor
   numeroMayor = numeroActual;
  }
 }
 printf("De los 3 numeros que proporcionaste, el mayor es %d\n", numeroMayor);
 return 0;
}

 

Para “optimizar” el algoritmo recorremos el arreglo desde 1, no desde 0 como siempre lo hacemos. Y suponemos que el mayor es el primer elemento, es decir, el del índice 0.

De todos modos, si el número más grande no es el primer elemento entonces en la comparación dentro del ciclo se asignará al nuevo valor.

Cuando ejecutamos el programa tenemos que introducir los 3 números. Aquí una captura:

Mayor de 3 números en C

El algoritmo es correcto.

Menor de 3 números en C

Únicamente cambiamos las comparaciones y nombres de variables. Queda así:

#include <stdio.h>

int main(int argc, char const *argv[])
{
 // Aquí almacenaremos los 3 números
 int numeros[3];

 for (int i = 0; i < 3; ++i)
 {
  printf("Por favor, ingresa el numero %d:\n", i + 1); // Sumar 1 porque empezamos desde 0
  scanf("%d", &numeros[i]);
 }

 //Suponemos que el menor es el primer número
 int numeroMenor = numeros[0];

 // Comenzar desde el 1, porque estamos suponiendo que el 0 es el menor
 for (int indice = 1; indice < 3; ++indice)
 {
  int numeroActual = numeros[indice];
  if (numeroActual < numeroMenor){  
   // Cambiar únicamente si el actual es menor que numeroMenor
   numeroMenor = numeroActual;
  }
 }
 printf("De los 3 numeros que proporcionaste, el menor es %d\n", numeroMenor);
 return 0;
}

Cuando lo ejecuto el resultado es este:

Menor de 3 números en C

El algoritmo es correcto.

Más números

Con este enfoque podemos comparar 4, 5 o más números cambiando pocas cosas. Para ejemplificar aquí dejo el fragmento de código para encontrar el mayor de 5 números:

#include <stdio.h>

int main(int argc, char const *argv[])
{
 // Aquí almacenaremos los 5 números
 int numeros[5];

 for (int i = 0; i < 5; ++i)
 {
  printf("Por favor, ingresa el numero %d:\n", i + 1); // Sumar 1 porque empezamos desde 0
  scanf("%d", &numeros[i]);
 }

 //Suponemos que el mayor es el primer número
 int numeroMayor = numeros[0];

 // Comenzar desde el 1, porque estamos suponiendo que el 0 es el mayor
 for (int indice = 1; indice < 5; ++indice)
 {
  int numeroActual = numeros[indice];
  if (numeroActual > numeroMayor){  
   // Cambiar únicamente si el actual es mayor que numeroMayor
   numeroMayor = numeroActual;
  }
 }
 printf("De los 5 numeros que proporcionaste, el mayor es %d\n", numeroMayor);
 return 0;
}

Con este resultado:

Mayor de 5 números en C

Y así podemos ir jugando con este maravilloso, poderoso, rápido y eficaz lenguaje que en lo personal respeto mucho.

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/

Ver comentarios

Entradas recientes

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 días 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 días 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 días hace

Errores de Comlink y algunas soluciones

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

2 días 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 días hace

Solución: Apache – Server unable to read htaccess file

Ayer estaba editando unos archivos que son servidos con el servidor Apache y al visitarlos…

3 días hace

Esta web usa cookies.