php

PHP – Generar histograma con arreglo

Hoy vamos a resolver un ejercicio en PHP que se trata de recorrer un arreglo, contar cuántas veces aparece un número y luego generar un histograma con asteriscos a partir del mismo. Básicamente es contar la cantidad de veces que aparece un número.

El ejercicio dice así:

Hacer un programa en PHP que recorra un arreglo y genere un histograma en base a los números de este arreglo. Un histograma representa que tanto un elemento aparece en un conjunto de datos.

Debe mostrar la frecuencia para todos los números del 1 al 5, incluso si no están presentes en el arreglo. Por ejemplo, para el arreglo: [1,2,1,3,3,1,2,1,5,1] el histograma se vería así:

1: *****
2: **
3: **
4:
5: *

Veamos cómo resolver este ejercicio con PHP, ciclo for, echo y foreach.

Explicación del algoritmo

Como el ejercicio solo tomará números del 1 al 5 podemos iniciar un diccionario (clave, valor) en donde la clave es el número y el valor es la cantidad de veces que el número aparece, en este caso el valor al inicio será 0.

Luego recorremos el arreglo y aumentamos el valor en el diccionario por cada número que vayamos encontrando, a este paso le podemos llamar como el paso del conteo.

Ahora ya tendremos nuestro diccionario, solo hace falta recorrerlo, ver la clave (que es el número) y el valor que es el conteo. Con el conteo hacemos un ciclo for para imprimir un asterisco.

Código PHP – Frecuencia de números

Histograma con PHP – Contar frecuencia de números

Una vez explicado el funcionamiento y algoritmo veamos el código PHP. Queda de la siguiente manera:

<?php
// https://parzibyte.me/blog
$diccionario = [
    1 => 0,
    2 => 0,
    3 => 0,
    4 => 0,
    5 => 0,
];
$miArray = [1, 2, 1, 3, 3, 1, 2, 1, 5, 1];
foreach ($miArray as $numero) {
    $diccionario[$numero]++;
}
foreach ($diccionario as $clave => $conteo) {
    echo "$clave: ";
    for ($x = 0; $x < $conteo; $x++) {
        echo "*";
    }
    echo "\n";
}

Por cierto, si los números no fueran del 1 al 5 podrías dejar el diccionario en blanco y agregar una comprobación antes de la línea 12: si ya existe lo aumentas, si no, lo declaras en 1.

La salida ya la pudiste ver en el encabezado de la sección, pero igualmente puedes probar el código en este enlace.

Nota: yo he ejecutado el archivo desde la terminal, pero también sirve si lo ejecutas en un servidor web como lo es Apache.

Aquí te dejo con más tutoriales y software escrito en PHP.

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

JavaScript – Dividir texto en varias líneas con espacio

Hoy te voy a enseñar a agregar un salto de línea a un texto para…

3 semanas hace

Emitir sonido y parpadear LED en impresora térmica

Algunas impresoras térmicas ESC POS tienen un buzzer o zumbador que puede emitir sonidos, también…

3 semanas hace

Tailwind CSS – Centrar verticalmente

En este corto tutorial de programación CSS con Tailwind vamos a ver cómo centrar un…

4 semanas hace

Cámara a impresora térmica – Aplicación web

Hoy te voy a enseñar una aplicación web (programada con JavaScript en el lado del…

4 semanas hace

Mejorar calidad de imágenes en impresora térmica

En este artículo te voy a enseñar una técnica para mejorar la calidad de las…

4 semanas hace

Convertir OffscreenCanvas a imagen en base64

La API de OffscreenCanvas permite trabajar con un canvas en JavaScript sin tener que usar…

4 semanas hace

Esta web usa cookies.