From d2eebdd78b8594455a10ddc69f5ab9f962d4ac1e Mon Sep 17 00:00:00 2001 From: dcsibon Date: Mon, 28 Oct 2024 15:31:47 +0100 Subject: [PATCH] Terminado los mensajes para los alumnos en la prueba --- otros/adivinar_numero_v3.py | 70 ++- otros/adivinar_numero_v3.py.bak | 584 ++++++++++++++++++++++++ otros/adivinar_numero_v3_alumnos.py | 83 ++-- otros/adivinar_numero_v3_alumnos.py.bak | 442 ++++++++++++++++++ 4 files changed, 1138 insertions(+), 41 deletions(-) create mode 100644 otros/adivinar_numero_v3.py.bak create mode 100644 otros/adivinar_numero_v3_alumnos.py.bak diff --git a/otros/adivinar_numero_v3.py b/otros/adivinar_numero_v3.py index 7e422a0..c044530 100644 --- a/otros/adivinar_numero_v3.py +++ b/otros/adivinar_numero_v3.py @@ -21,11 +21,11 @@ def limpiar_pantalla(): """ Limpia la consola según el sistema operativo. - En sistemas Windows utiliza el comando 'cls', en Linux o macOS utiliza 'clear'. + En sistemas Windows utiliza el comando 'cls', en Linux o macOS utiliza 'clear' (os.name == "posix"). """ try: # Debe funcionar en todos los sistemas operativos - comando = 'cls' if os.name == 'nt' else 'clear' + comando = 'clear' if os.name == 'posix' else 'cls' os.system(comando) except Exception as e: mostrar_error(f"Problemas al intentar limpiar la pantalla: {e}") @@ -41,9 +41,10 @@ def pausa(tiempo = 0, tecla_enter = False, limpiar = True): tecla_enter (bool, opcional): Si es True y `tiempo` es 0, espera a que el usuario presione ENTER para continuar. limpiar (bool, opcional): Si es True, limpia la pantalla después de la pausa. - """ - # time.sleep() + # Desarrolla esta función y ejecute una pausa de un tiempo en segundos con time.sleep() + # o una pausa esperando a que el usuario "\nPresione ENTER para continuar..." + # Además, dependiendo del parámetro opcional limpiar debe limpiar la consola o no if tecla_enter: input("\nPresione ENTER para continuar...") elif tiempo > 0: @@ -69,7 +70,8 @@ def mostrar_titulo(seccion: int, intentos: int = 0): #else: # print(f"{TITULOS[0]}\n\n") # - # Hacer lo mismo pero útilizando try-except para controlar si la seccion está fuera de rango + # Hacer lo mismo que el código comentado, pero útilizando try-except + # para controlar si la seccion está fuera de rango try: titulo = TITULOS[seccion].format(intentos=intentos) if intentos > 0 else TITULOS[seccion] except (IndexError, KeyError): @@ -105,7 +107,7 @@ def evaluar_diferencia(numero: int, numero_oculto: int, frio: int, caliente: int - 1 si el número está "Caliente". - 2 si el número está "Te Quemas". - Ejemplos: + Examples: >>> evaluar_diferencia(50, 100, 15, 5) 0 # Frío @@ -140,9 +142,21 @@ def obtener_pista(numero: int, numero_oculto: int, intentos: int, frio: int, cal Returns: str: Frase con la pista para el juego. + + Note: + La función retorna uno de los siguientes mensajes según la proximidad del número ingresado al número oculto: + + - "* FRÍO, FRÍO, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* FRÍO, FRÍO, el número oculto es MAYOR... ¡te quedan N intentos!\n" + - "* CALIENTE, CALIENTE, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* CALIENTE, CALIENTE, el número oculto es MAYOR... ¡te quedan N intentos!\n" + - "* TE QUEMAS, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* TE QUEMAS, el número oculto es MAYOR... ¡te quedan N intentos!\n" + + En los mensajes, "N" representa el número de intentos restantes. """ # Realizar la función según la documentación que observáis - # Debéis hacer una llamada a la función evaluar_diferencia() + # Daros cuenta que debéis hacer una llamada a la función evaluar_diferencia() diferencia_code = evaluar_diferencia(numero, numero_oculto, frio, caliente) # Determinamos el mensaje según el código de diferencia @@ -461,21 +475,28 @@ def elegir_opcion_menu() -> int: return opcion -def jugar(numero_oculto, minimo, maximo, intentos, frio, caliente): +def jugar(numero_oculto: int, minimo: int, maximo: int, intentos: int, frio: int, caliente: int): """ - Gestiona el proceso del juego de adivinar el número oculto y muestra los resultados. + Gestiona el proceso del juego de adivinar el número oculto y muestra los resultados al finalizar. Args: - numero_oculto (int): Número que debe ser adivinado. - intentos (int): Número de intentos disponibles. - frio (int): Diferencia máxima para la pista "Frío". - caliente (int): Diferencia máxima para la pista "Caliente". + numero_oculto (int): Número que debe ser adivinado por el jugador. + minimo (int): El límite inferior del rango de números posibles. + maximo (int): El límite superior del rango de números posibles. + intentos (int): Número máximo de intentos permitidos para el jugador. + frio (int): Diferencia mínima para que se active la pista "Frío". + caliente (int): Diferencia mínima para que se active la pista "Caliente". + + Note: + - Un mensaje de éxito si el jugador adivina el número, indicando los intentos utilizados. + - Un mensaje de fin de juego si el jugador no logra adivinar el número, mostrando el número oculto. """ # Mostrar el mensaje correspondiente al final del juego: # - Si lo adivinó => "\n¡Bravo! ¡Lo conseguiste en N intentos!" # - Si no lo consiguió => "\nGAME OVER - ¡Otra vez será! (#XX#)" # Donde N es el númnero de intentos en el que consiguió acertarlo y XX el número oculto. - # También debes corregir posibles errores... + # Recuerda que debes mostrar dichos mensajes hasta que el usuario presione ENTER... + # También debes corregir posibles errores... limpiar_pantalla() mostrar_titulo(3, intentos) numero_adivinado, intentos_realizados = adivina_el_numero(numero_oculto, intentos, minimo, maximo, frio, caliente) @@ -499,13 +520,32 @@ def genera_numero_oculto(minimo: int, maximo: int) -> int: Returns: int: Número generado aleatoriamente entre mínimo y máximo. """ + # Crear la documentación recomendada para esta función return random.randint(minimo, maximo) def main(): """ Función principal que ejecuta el flujo completo del juego de adivinar el número oculto. - Configura los parámetros iniciales y gestiona el bucle principal del menú. + + Configura los parámetros iniciales, muestra la configuración actual, y gestiona el bucle principal del menú + para permitir al usuario jugar, configurar el juego, mostrar la configuración actual del juego o salir. + + Note: + 1. Limpia la pantalla, muestra el título de bienvenida y hace una pausa inicial. + 2. Configura los parámetros iniciales del juego: + - minimo: Límite inferior del rango de números (por defecto 0). + - maximo: Límite superior del rango de números (por defecto 100). + - frio: Diferencia mínima para la pista "Frío" (por defecto 15). + - caliente: Diferencia mínima para la pista "Caliente" (por defecto 5). + - intentos: Número máximo de intentos (por defecto 5). + 3. Muestra la configuración actual del juego y pide presionar una tecla para continuar... + 4. Permite al usuario interactuar mediante un menú: + - Opción 1: Jugar e intentar adivinar el número oculto. + - Opción 2: Configurar los parámetros del juego. + - Opción 3: Visualizar la configuración actual del juego. + - Opción 4: Salir del juego. + 5. Finaliza el juego mostrando un mensaje de despedida. """ # Debe limpiar la pantalla, mostrar el título de la sección correspondiente y hacer una pausa de 2 segundos # Corrige los posibles errores... diff --git a/otros/adivinar_numero_v3.py.bak b/otros/adivinar_numero_v3.py.bak new file mode 100644 index 0000000..666507d --- /dev/null +++ b/otros/adivinar_numero_v3.py.bak @@ -0,0 +1,584 @@ +# Importa los paquetes que necesites. +# Para mostrar cualquier ERROR debes usar la función mostrar_error(), no hagas print directamente. + +import os +import random +import time + + +TITULOS = ( + "--- SECCIÓN NO DEFINIDA ---", + "--- BIENVENIDOS AL JUEGO DE ADIVINAR EL NÚMERO OCULTO ---", + "--- MENÚ DE ADIVINA EL NÚMERO OCULTO ---", + "--- ADIVINA EL NÚMERO OCULTO EN {intentos} INTENTOS ---", + "--- CONFIGURA EL JUEGO DE ADIVINA EL NÚMERO OCULTO ---", + "--- CONFIGURACIÓN ACTUAL DE ADIVINA EL NÚMERO OCULTO ---", +) + + + +def limpiar_pantalla(): + """ + Limpia la consola según el sistema operativo. + + En sistemas Windows utiliza el comando 'cls', en Linux o macOS utiliza 'clear' (os.name == "posix"). + """ + try: + # Debe funcionar en todos los sistemas operativos + comando = 'clear' if os.name == 'posix' else 'cls' + os.system(comando) + except Exception as e: + mostrar_error(f"Problemas al intentar limpiar la pantalla: {e}") + + +def pausa(tiempo = 0, tecla_enter = False, limpiar = True): + """ + Pausa la ejecución del programa según los parámetros especificados. + + Args: + tiempo (int, opcional): Número de segundos para la pausa. Si es mayor a 0, se pausa + por este tiempo y se ignora `tecla_enter`. + tecla_enter (bool, opcional): Si es True y `tiempo` es 0, espera a que el usuario presione + ENTER para continuar. + limpiar (bool, opcional): Si es True, limpia la pantalla después de la pausa. + """ + # Desarrolla esta función y ejecute una pausa de un tiempo en segundos con time.sleep() + # o una pausa esperando a que el usuario "\nPresione ENTER para continuar..." + # Además, dependiendo del parámetro opcional limpiar debe limpiar la consola o no + if tecla_enter: + input("\nPresione ENTER para continuar...") + elif tiempo > 0: + time.sleep(tiempo) + + if limpiar: + limpiar_pantalla() + + +def mostrar_titulo(seccion: int, intentos: int = 0): + """ + Muestra el título correspondiente a la sección del juego. + + Args: + seccion (int): El identificador de la sección. Los valores válidos son de 1 a len(TITULOS). + intentos (int): Número de intentos que puede ser usado en el título si corresponde. + """ + #if 0 < seccion < len(TITULOS): + # if intentos > 0: + # print(TITULOS[seccion].format(intentos = intentos) + "\n\n") + # else: + # print(f"{TITULOS[seccion]}\n\n") + #else: + # print(f"{TITULOS[0]}\n\n") + # + # Hacer lo mismo que el código comentado, pero útilizando try-except + # para controlar si la seccion está fuera de rango + try: + titulo = TITULOS[seccion].format(intentos=intentos) if intentos > 0 else TITULOS[seccion] + except (IndexError, KeyError): + titulo = TITULOS[0] # Título de error o default si `seccion` está fuera del rango + + print(f"{titulo}\n\n") + + +def mostrar_error(msjError: str): + """Muestra un mensaje de error en la consola y pausa la ejecución. + + Args: + msjError (str): Mensaje de error que se mostrará al usuario. + """ + print("\n*ERROR* " + str(msjError)) + pausa(1) + + +def evaluar_diferencia(numero: int, numero_oculto: int, frio: int, caliente: int) -> int: + """ + Evalúa la distancia entre el número oculto y el ingresado, y devuelve un código numérico + basado en la cercanía. + + Args: + numero (int): Número ingresado por el usuario. + numero_oculto (int): Número que debe ser adivinado. + frio (int): Diferencia máxima para considerar la pista como "Frío". + caliente (int): Diferencia máxima para considerar la pista como "Caliente". + + Returns: + int: + - 0 si el número está "Frío". + - 1 si el número está "Caliente". + - 2 si el número está "Te Quemas". + + Examples: + >>> evaluar_diferencia(50, 100, 15, 5) + 0 # Frío + + >>> evaluar_diferencia(95, 100, 15, 5) + 1 # Caliente + + >>> evaluar_diferencia(98, 100, 15, 5) + 2 # Te Quemas + """ + # Realizar la función según la documentación que observáis + diferencia = abs(numero_oculto - numero) + + if diferencia > frio: + return 0 # Frío + elif diferencia > caliente: + return 1 # Caliente + else: + return 2 # Te Quemas + + +def obtener_pista(numero: int, numero_oculto: int, intentos: int, frio: int, caliente: int) -> str: + """ + Obtiene una pista combinando la distancia (frío, caliente, te quemas) y si el número oculto + es mayor o menor. + + Args: + numero (int): Número ingresado por el usuario. + numero_oculto (int): Número que debe ser adivinado. + intentos (int): Cantidad de intentos restantes. + frio (int): Diferencia máxima para considerar la pista como "Frío". + caliente (int): Diferencia máxima para considerar la pista como "Caliente". + + Returns: + str: Frase con la pista para el juego. + + Note: + La función retorna uno de los siguientes mensajes según la proximidad del número ingresado al número oculto: + + - "* FRÍO, FRÍO, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* FRÍO, FRÍO, el número oculto es MAYOR... ¡te quedan N intentos!\n" + - "* CALIENTE, CALIENTE, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* CALIENTE, CALIENTE, el número oculto es MAYOR... ¡te quedan N intentos!\n" + - "* TE QUEMAS, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* TE QUEMAS, el número oculto es MAYOR... ¡te quedan N intentos!\n" + + En los mensajes, "N" representa el número de intentos restantes. + """ + # Realizar la función según la documentación que observáis + # Daros cuenta que debéis hacer una llamada a la función evaluar_diferencia() + diferencia_code = evaluar_diferencia(numero, numero_oculto, frio, caliente) + + # Determinamos el mensaje según el código de diferencia + if diferencia_code == 0: + pista = "* FRÍO, FRÍO," + elif diferencia_code == 1: + pista = "* CALIENTE, CALIENTE," + else: + pista = "* TE QUEMAS," + + pista += " el número oculto es " + + if numero_oculto > numero: + pista += "MAYOR... " + else: + pista += "MENOR... " + + if intentos > 1: + pista += f"¡te quedan {intentos} intentos!\n" + else: + pista += f"¡te queda {intentos} intento!\n" + + return pista + + +def pedir_numero_usuario(mensaje: str, minimo: int = None, maximo: int = None) -> int: + """ + Solicita al usuario que introduzca un número entero válido. + + Args: + mensaje (str): Mensaje que se muestra al usuario para pedir el número. + + Returns: + int: Número entero ingresado por el usuario. + + Raises: + ValueError: Si el valor introducido no puede convertirse a un número entero. + """ + # El código de esta función NO SE PUEDE TOCAR! Ya está terminada + try: + num = int(input(mensaje).strip()) + except ValueError: + raise ValueError("El número introducido no es un entero válido!") + + if minimo != None and num < minimo: + raise ValueError(f"El número introducido no es correcto (mínimo: {minimo})") + + if maximo != None and num > maximo: + raise ValueError(f"El número introducido no es correcto (máximo: {maximo})") + + return num + + +def adivina_el_numero(numero_oculto: int, total_intentos: int, minimo: int, maximo: int, frio: int, caliente: int): + """ + Gestiona el proceso de adivinación del número oculto, permitiendo que el usuario ingrese números. + + Args: + numero_oculto (int): Número que debe ser adivinado. + total_intentos (int): Cantidad total de intentos permitidos. + minimo (int): Número mínimo que puede alcanzar el número oculto. + maximo (int): Número máximo que puede alcanzar el número oculto. + frio (int): Diferencia máxima para considerar la pista como "Frío". + caliente (int): Diferencia máxima para considerar la pista como "Caliente". + + Returns: + tuple: Un booleano que indica si el número fue adivinado y el número de intentos realizados. + """ + # Hacer un bucle hasta que se adivine el número o realice todos los intentos posibles... + # Utiliza pedir_numero_usuario("¿Qué número es? ", minimo, maximo) + # Muestra la pista con obtener_pista() si el número introducido no es el oculto (obtener_pista()). + # La función debe retornar si el número fue adivinado y los intentos realizados. + intentos_realizados = 0 + numero_adivinado = False + + while not numero_adivinado and total_intentos > 0: + + numero = None + try: + numero = pedir_numero_usuario("¿Qué número es? ", minimo, maximo) + except ValueError as e: + mostrar_error(e) + + if numero != None: + intentos_realizados += 1 + total_intentos -= 1 + + if numero != numero_oculto: + print(f"\n{obtener_pista(numero, numero_oculto, total_intentos, frio, caliente)}") + else: + numero_adivinado = True + + return numero_adivinado, intentos_realizados + + +def configurar_rangos_numeros() -> tuple: + """ + Configura el rango de números válidos para el juego solicitando los valores mínimo y máximo. + + Returns: + tuple: Una tupla que contiene el número mínimo y el número máximo configurados para el juego. + + Raises: + ValueError: Si el valor mínimo es superior al máximo o si la diferencia entre el máximo y + el mínimo es menor a 100. + """ + # Debe usar pedir_numero_usuario() para solicitar el número mínimo y máximo del + # rango posible para el número oculto. + # Requisitos que debe cumplir para aceptar el mínimo y máximo: + # 1. El número mínimo debe ser menor que el máximo. + # (*ERROR* El valor mínimo no puede ser superior al máximo.) + # 2. La diferencia entre ambos debe ser igual o superior a 100. + # (*ERROR* El rango del número oculto debe ser igual o superior a 100.) + rango_valido = False + + while not rango_valido: + try: + + minimo = pedir_numero_usuario("Introduce el mínimo número posible: ") + maximo = pedir_numero_usuario("Introduce el máximo número posible: ") + + if minimo > maximo: + raise ValueError("El valor mínimo no puede ser superior al máximo.") + if abs(maximo - minimo) < 100: + raise ValueError("El rango del número oculto debe ser igual o superior a 100.") + + except ValueError as e: + mostrar_error(e) + else: + rango_valido = True + + return minimo, maximo + + +def configurar_pistas(minimo: int, maximo: int) -> tuple: + """ + Configura los valores de diferencia para las pistas "Frío" y "Caliente". + + Args: + minimo (int): El número mínimo dentro del rango de juego. + maximo (int): El número máximo dentro del rango de juego. + + Returns: + tuple: Una tupla que contiene los valores para las pistas de "Frío" y "Caliente". + + Raises: + ValueError: Si la diferencia para la pista "Frío" no es mayor que la de "Caliente", + si "Caliente" es menor o igual a 0, o si alguno de los valores se sale + del rango (minimo, maximo). + """ + # Debe usar pedir_numero_usuario() para solicitar los valores de diferencia + # para las pistas "Frío" y "Caliente". + # Requisitos que debe cumplir para aceptar estos valores: + # 1. La diferencia para la pista FRÍO no puede ser inferior o igual a la CALIENTE. + # (*ERROR* La diferencia para la pista FRÍO no puede ser inferior o igual a la CALIENTE!) + # 2. La diferencia para la pista CALIENTE debe ser superior a 0. + # (*ERROR* La diferencia para la pista CALIENTE debe ser superior a 0!) + # 3. La diferencia para la pista FRÍO debe estar entre minimo y maximo. + # (*ERROR* La diferencia para la pista FRÍO debe estar entre {minimo} y {maximo}!) + # 4. La diferencia para la pista CALIENTE debe estar entre minimo y maximo. + # (*ERROR* La diferencia para la pista CALIENTE debe estar entre {minimo} y {maximo}!) + valores_validas = False + + while not valores_validas: + try: + + frio = pedir_numero_usuario("Introduce la diferencia para mostrar la pista FRÍO, FRÍO: ", minimo, maximo) + caliente = pedir_numero_usuario("Introduce la diferencia para mostrar la pista CALIENTE, CALIENTE: ", minimo, maximo) + + if frio <= caliente: + raise ValueError("La diferencia para la pista FRÍO no puede ser inferior o igual a la CALIENTE!") + if caliente <= 0: + raise ValueError("La diferencia para la pista CALIENTE debe ser superior a 0!") + if not (minimo <= frio <= maximo): + raise ValueError(f"La diferencia para la pista FRÍO debe estar entre {minimo} y {maximo}!") + if not (minimo <= caliente <= maximo): + raise ValueError(f"La diferencia para la pista CALIENTE debe estar entre {minimo} y {maximo}!") + + except ValueError as e: + mostrar_error(e) + else: + valores_validas = True + + return frio, caliente + + +def configurar_intentos(rango_numero_oculto) -> int: + """ + Configura el número de intentos para adivinar el número oculto, asegurando que el valor es positivo + y no excede el 10% del rango de números. + + Args: + rango_numero_oculto (int): El rango del número oculto (diferencia entre el máximo y el mínimo). + + Returns: + int: El número de intentos configurado por el usuario. + + Raises: + ValueError: Si el número de intentos es menor o igual a 0 o si excede el 10% del rango. + """ + # Debe usar pedir_numero_usuario() para solicitar los intentos posibles. + # Requisitos que debe cumplir para aceptar el valor: + # 1. Número entero positivo mayor que cero. + # (*ERROR* El número de intentos debe ser un número entero positivo!) + # 2. Inferior al 10% del rango del número oculto. + # (*ERROR* El número de intentos no puede ser superior al 10% del rango del número oculto!) + intentos_validos = False + + while not intentos_validos: + try: + intentos = pedir_numero_usuario("Introduce el número de intentos: ") + + if intentos <= 0: + raise ValueError("El número de intentos debe ser un número entero positivo!") + if intentos > int(rango_numero_oculto * 0.1): + raise ValueError("El número de intentos no puede ser superior al 10% del rango del número oculto!") + + except ValueError as e: + mostrar_error(e) + else: + intentos_validos = True + + return intentos + + +def configurar_juego() -> tuple: + """ + Configura todos los parámetros del juego: rango de números, pistas e intentos. + + Returns: + tuple: Mínimo, máximo, número de intentos, valor para "Frío" y valor para "Caliente". + """ + # Completar la llamada a las funciones correctas... + limpiar_pantalla() + mostrar_titulo(4) + + minimo, maximo = configurar_rangos_numeros() + frio, caliente = configurar_pistas(minimo, maximo) + intentos = configurar_intentos(abs(maximo - minimo)) + + return minimo, maximo, intentos, frio, caliente + + +def mostrar_configuracion(minimo, maximo, intentos, frio, caliente): + """ + Muestra la configuración actual del juego. + + Args: + minimo (int): Mínimo número del rango. + maximo (int): Máximo número del rango. + intentos (int): Número de intentos posibles. + frio (int): Diferencia mayor para la pista "Frío". + caliente (int): Diferencia mayor para la pista "Caliente". + """ + # Corregir posibles errores... + limpiar_pantalla() + mostrar_titulo(5) + print(f"* El número oculto será un número entre {minimo} y {maximo}.") + print(f"* El número de intentos es {intentos}.") + print(f"* Pista FRÍO si la diferencia es mayor a {frio}.") + print(f"* Pista CALIENTE si la diferencia es mayor a {caliente}.") + print(f"* Pista TE QUEMAS si la diferencia es menor.") + pausa(tecla_enter = True) + + +def mostrar_menu(): + """ + Muestra el menú principal del juego. + """ + # Corregir posibles errores... + limpiar_pantalla() + mostrar_titulo(2) + print("1. Jugar.") + print("2. Configurar.") + print("3. Mostrar configuración.") + print("4. Salir.\n") + + +def comprobar_opcion(opcion: int) -> bool: + """ + Comprueba si la opción elegida está dentro del rango permitido (1-4). + + Args: + opcion (int): Opción ingresada por el usuario. + + Returns: + bool: True si la opción es válida, False en caso contrario. + """ + # Crear la documentación recomendada para esta función + return 1 <= opcion <= 4 + + +def elegir_opcion_menu() -> int: + """ + Permite al usuario elegir una opción del menú. + + Returns: + int: La opción elegida por el usuario. + """ + # Corregir posibles errores... + opcion_correcta = False + + while not opcion_correcta: + mostrar_menu() + try: + opcion = pedir_numero_usuario("Elije => ") + + except ValueError: + mostrar_error("Ha introducido un número entero no válido!") + else: + opcion_correcta = comprobar_opcion(opcion) + + if not opcion_correcta: + mostrar_error(f"Opción {opcion} incorrecta! (1-4)") + + return opcion + + +def jugar(numero_oculto: int, minimo: int, maximo: int, intentos: int, frio: int, caliente: int): + """ + Gestiona el proceso del juego de adivinar el número oculto y muestra los resultados al finalizar. + + Args: + numero_oculto (int): Número que debe ser adivinado por el jugador. + minimo (int): El límite inferior del rango de números posibles. + maximo (int): El límite superior del rango de números posibles. + intentos (int): Número máximo de intentos permitidos para el jugador. + frio (int): Diferencia mínima para que se active la pista "Frío". + caliente (int): Diferencia mínima para que se active la pista "Caliente". + + Note: + - Un mensaje de éxito si el jugador adivina el número, indicando los intentos utilizados. + - Un mensaje de fin de juego si el jugador no logra adivinar el número, mostrando el número oculto. + """ + # Mostrar el mensaje correspondiente al final del juego: + # - Si lo adivinó => "\n¡Bravo! ¡Lo conseguiste en N intentos!" + # - Si no lo consiguió => "\nGAME OVER - ¡Otra vez será! (#XX#)" + # Donde N es el númnero de intentos en el que consiguió acertarlo y XX el número oculto. + # Recuerda que debes mostrar dichos mensajes hasta que el usuario presione ENTER... + # También debes corregir posibles errores... + limpiar_pantalla() + mostrar_titulo(3, intentos) + numero_adivinado, intentos_realizados = adivina_el_numero(numero_oculto, intentos, minimo, maximo, frio, caliente) + + if numero_adivinado: + print(f"\n¡Bravo! ¡Lo conseguiste en {intentos_realizados} intentos!") + else: + print(f"\nGAME OVER - ¡Otra vez será! (#{numero_oculto}#)") + + pausa(tecla_enter = True) + + +def genera_numero_oculto(minimo: int, maximo: int) -> int: + """ + Genera un número oculto aleatorio dentro de un rango determinado. + + Args: + minimo (int): El valor mínimo posible. + maximo (int): El valor máximo posible. + + Returns: + int: Número generado aleatoriamente entre mínimo y máximo. + """ + return random.randint(minimo, maximo) + + +def main(): + """ + Función principal que ejecuta el flujo completo del juego de adivinar el número oculto. + + Configura los parámetros iniciales, muestra la configuración actual, y gestiona el bucle principal del menú + para permitir al usuario jugar, configurar el juego, mostrar la configuración actual del juego o salir. + + Note: + 1. Limpia la pantalla, muestra el título de bienvenida y hace una pausa inicial. + 2. Configura los parámetros iniciales del juego: + - minimo: Límite inferior del rango de números (por defecto 0). + - maximo: Límite superior del rango de números (por defecto 100). + - frio: Diferencia mínima para la pista "Frío" (por defecto 15). + - caliente: Diferencia mínima para la pista "Caliente" (por defecto 5). + - intentos: Número máximo de intentos (por defecto 5). + 3. Muestra la configuración actual del juego y pide presionar una tecla para continuar... + 4. Permite al usuario interactuar mediante un menú: + - Opción 1: Jugar e intentar adivinar el número oculto. + - Opción 2: Configurar los parámetros del juego. + - Opción 3: Visualizar la configuración actual del juego. + - Opción 4: Salir del juego. + 5. Finaliza el juego mostrando un mensaje de despedida. + """ + # Debe limpiar la pantalla, mostrar el título de la sección correspondiente y hacer una pausa de 2 segundos + # Corrige los posibles errores... + limpiar_pantalla() + mostrar_titulo(1) + pausa(2) + + # Configuración inicial por defecto + minimo = 0 + maximo = 100 + frio = 15 + caliente = 5 + intentos = 5 + + mostrar_configuracion(minimo, maximo, intentos, frio, caliente) + + salir = False + + while not salir: + opcion = elegir_opcion_menu() + + if opcion == 1: + numero_oculto = genera_numero_oculto(minimo, maximo) + jugar(numero_oculto, minimo, maximo, intentos, frio, caliente) + elif opcion == 2: + minimo, maximo, intentos, frio, caliente = configurar_juego() + elif opcion == 3: + mostrar_configuracion(minimo, maximo, intentos, frio, caliente) + else: + salir = True + + limpiar_pantalla() + print("Bye, bye...\n\n") + + +if __name__ == "__main__": + main() diff --git a/otros/adivinar_numero_v3_alumnos.py b/otros/adivinar_numero_v3_alumnos.py index 203648c..e163153 100644 --- a/otros/adivinar_numero_v3_alumnos.py +++ b/otros/adivinar_numero_v3_alumnos.py @@ -16,7 +16,7 @@ def limpiar_pantalla(): """ Limpia la consola según el sistema operativo. - En sistemas Windows utiliza el comando 'cls', en Linux o macOS utiliza 'clear'. + En sistemas Windows utiliza el comando 'cls', en Linux o macOS utiliza 'clear' (os.name == "posix"). """ try: # Debe funcionar en todos los sistemas operativos @@ -37,7 +37,9 @@ def pausa(tiempo = 0, tecla_enter = False, limpiar = True): limpiar (bool, opcional): Si es True, limpia la pantalla después de la pausa. """ - # time.sleep() + # Desarrolla esta función y ejecute una pausa de un tiempo en segundos con time.sleep() + # o una pausa esperando a que el usuario "\nPresione ENTER para continuar..." + # Además, dependiendo del parámetro opcional limpiar debe limpiar la consola o no def mostrar_titulo(seccion: int, intentos: int = 0): @@ -56,7 +58,8 @@ def mostrar_titulo(seccion: int, intentos: int = 0): #else: # print(f"{TITULOS[0]}\n\n") # - # Hacer lo mismo pero útilizando try-except para controlar si la seccion está fuera de rango + # Hacer lo mismo que el código comentado, pero útilizando try-except + # para controlar si la seccion está fuera de rango def mostrar_error(msjError: str): @@ -113,9 +116,21 @@ def obtener_pista(numero: int, numero_oculto: int, intentos: int, frio: int, cal Returns: str: Frase con la pista para el juego. + + Note: + La función retorna uno de los siguientes mensajes según la proximidad del número ingresado al número oculto: + + - "* FRÍO, FRÍO, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* FRÍO, FRÍO, el número oculto es MAYOR... ¡te quedan N intentos!\n" + - "* CALIENTE, CALIENTE, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* CALIENTE, CALIENTE, el número oculto es MAYOR... ¡te quedan N intentos!\n" + - "* TE QUEMAS, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* TE QUEMAS, el número oculto es MAYOR... ¡te quedan N intentos!\n" + + En los mensajes, "N" representa el número de intentos restantes. """ # Realizar la función según la documentación que observáis - # Debéis hacer una llamada a la función evaluar_diferencia() + # Daros cuenta que debéis hacer una llamada a la función evaluar_diferencia() def pedir_numero_usuario(mensaje: str, minimo: int = None, maximo: int = None) -> int: @@ -293,10 +308,10 @@ def mostrar_menu(): """ # Corregir posibles errores... mostrar_titulo() - print("1. Jugar.") - print("2. Configurar.") - print("3. Mostrar configuración.") - print("4. Salir.\n") + input("1. Jugar.") + input("2. Configurar.") + input("3. Mostrar configuración.") + input("4. Salir.\n") limpiar_pantalla() @@ -327,20 +342,27 @@ def elegir_opcion_menu() -> int: -def jugar(numero_oculto, intentos, frio, caliente): +def jugar(numero_oculto: int, intentos: int, frio: int, caliente: int): """ - Gestiona el proceso del juego de adivinar el número oculto y muestra los resultados. + Gestiona el proceso del juego de adivinar el número oculto y muestra los resultados al finalizar. Args: - numero_oculto (int): Número que debe ser adivinado. - intentos (int): Número de intentos disponibles. - frio (int): Diferencia máxima para la pista "Frío". - caliente (int): Diferencia máxima para la pista "Caliente". + numero_oculto (int): Número que debe ser adivinado por el jugador. + minimo (int): El límite inferior del rango de números posibles. + maximo (int): El límite superior del rango de números posibles. + intentos (int): Número máximo de intentos permitidos para el jugador. + frio (int): Diferencia mínima para que se active la pista "Frío". + caliente (int): Diferencia mínima para que se active la pista "Caliente". + + Note: + - Un mensaje de éxito si el jugador adivina el número, indicando los intentos utilizados. + - Un mensaje de fin de juego si el jugador no logra adivinar el número, mostrando el número oculto. """ # Mostrar el mensaje correspondiente al final del juego: # - Si lo adivinó => "\n¡Bravo! ¡Lo conseguiste en N intentos!" # - Si no lo consiguió => "\nGAME OVER - ¡Otra vez será! (#XX#)" # Donde N es el númnero de intentos en el que consiguió acertarlo y XX el número oculto. + # Recuerda que debes mostrar dichos mensajes hasta que el usuario presione ENTER... # También debes corregir posibles errores... limpiar_pantalla() mostrar_titulo(3, intentos) @@ -349,24 +371,33 @@ def jugar(numero_oculto, intentos, frio, caliente): pausa -def genera_numero_oculto(minimo: int, maximo: int) -> int: - """ - Genera un número oculto aleatorio dentro de un rango determinado. - - Args: - minimo (int): El valor mínimo posible. - maximo (int): El valor máximo posible. - - Returns: - int: Número generado aleatoriamente entre mínimo y máximo. - """ +def genera_numero_oculto(): + # Crear la documentación recomendada para esta función return random.randint(minimo, maximo) def main(): """ Función principal que ejecuta el flujo completo del juego de adivinar el número oculto. - Configura los parámetros iniciales y gestiona el bucle principal del menú. + + Configura los parámetros iniciales, muestra la configuración actual, y gestiona el bucle principal del menú + para permitir al usuario jugar, configurar el juego, mostrar la configuración actual del juego o salir. + + Note: + 1. Limpia la pantalla, muestra el título de bienvenida y hace una pausa inicial. + 2. Configura los parámetros iniciales del juego: + - minimo: Límite inferior del rango de números (por defecto 0). + - maximo: Límite superior del rango de números (por defecto 100). + - frio: Diferencia mínima para la pista "Frío" (por defecto 15). + - caliente: Diferencia mínima para la pista "Caliente" (por defecto 5). + - intentos: Número máximo de intentos (por defecto 5). + 3. Muestra la configuración actual del juego y pide presionar una tecla para continuar... + 4. Permite al usuario interactuar mediante un menú: + - Opción 1: Jugar e intentar adivinar el número oculto. + - Opción 2: Configurar los parámetros del juego. + - Opción 3: Visualizar la configuración actual del juego. + - Opción 4: Salir del juego. + 5. Finaliza el juego mostrando un mensaje de despedida. """ # Debe limpiar la pantalla, mostrar el título de la sección correspondiente y hacer una pausa de 2 segundos # Corrige los posibles errores... diff --git a/otros/adivinar_numero_v3_alumnos.py.bak b/otros/adivinar_numero_v3_alumnos.py.bak new file mode 100644 index 0000000..96dd9c0 --- /dev/null +++ b/otros/adivinar_numero_v3_alumnos.py.bak @@ -0,0 +1,442 @@ +# Importa los paquetes que necesites. +# Para mostrar cualquier ERROR debes usar la función mostrar_error(), no hagas print directamente. + + +TITULOS = ( + "--- SECCIÓN NO DEFINIDA ---", + "--- BIENVENIDOS AL JUEGO DE ADIVINAR EL NÚMERO OCULTO ---", + "--- MENÚ DE ADIVINA EL NÚMERO OCULTO ---", + "--- ADIVINA EL NÚMERO OCULTO EN {intentos} INTENTOS ---", + "--- CONFIGURA EL JUEGO DE ADIVINA EL NÚMERO OCULTO ---", + "--- CONFIGURACIÓN ACTUAL DE ADIVINA EL NÚMERO OCULTO ---", +) + + +def limpiar_pantalla(): + """ + Limpia la consola según el sistema operativo. + + En sistemas Windows utiliza el comando 'cls', en Linux o macOS utiliza 'clear' (os.name == "posix"). + """ + try: + # Debe funcionar en todos los sistemas operativos + os.system(comando) + except Exception as e: + mostrar_error(f"Problemas al intentar limpiar la pantalla: {e}") + + +def pausa(tiempo = 0, tecla_enter = False, limpiar = True): + """ + Pausa la ejecución del programa según los parámetros especificados. + + Args: + tiempo (int, opcional): Número de segundos para la pausa. Si es mayor a 0, se pausa + por este tiempo y se ignora `tecla_enter`. + tecla_enter (bool, opcional): Si es True y `tiempo` es 0, espera a que el usuario presione + ENTER para continuar. + limpiar (bool, opcional): Si es True, limpia la pantalla después de la pausa. + + """ + # Desarrolla esta función y ejecute una pausa de un tiempo en segundos con time.sleep() + # o una pausa esperando a que el usuario "\nPresione ENTER para continuar..." + # Además, dependiendo del parámetro opcional limpiar debe limpiar la consola o no + + +def mostrar_titulo(seccion: int, intentos: int = 0): + """ + Muestra el título correspondiente a la sección del juego. + + Args: + seccion (int): El identificador de la sección. Los valores válidos son de 1 a len(TITULOS). + intentos (int): Número de intentos que puede ser usado en el título si corresponde. + """ + #if 0 < seccion < len(TITULOS): + # if intentos > 0: + # print(TITULOS[seccion].format(intentos = intentos) + "\n\n") + # else: + # print(f"{TITULOS[seccion]}\n\n") + #else: + # print(f"{TITULOS[0]}\n\n") + # + # Hacer lo mismo que el código comentado, pero útilizando try-except + # para controlar si la seccion está fuera de rango + + +def mostrar_error(msjError: str): + """Muestra un mensaje de error en la consola y pausa la ejecución. + + Args: + msjError (str): Mensaje de error que se mostrará al usuario. + """ + print("\n*ERROR* " + str(msjError)) + pausa(1) + + +def evaluar_diferencia(numero: int, numero_oculto: int, frio: int, caliente: int) -> int: + """ + Evalúa la distancia entre el número oculto y el ingresado, y devuelve un código numérico + basado en la cercanía. + + Args: + numero (int): Número ingresado por el usuario. + numero_oculto (int): Número que debe ser adivinado. + frio (int): Diferencia máxima para considerar la pista como "Frío". + caliente (int): Diferencia máxima para considerar la pista como "Caliente". + + Returns: + int: + - 0 si el número está "Frío". + - 1 si el número está "Caliente". + - 2 si el número está "Te Quemas". + + Ejemplos: + >>> evaluar_diferencia(50, 100, 15, 5) + 0 # Frío + + >>> evaluar_diferencia(95, 100, 15, 5) + 1 # Caliente + + >>> evaluar_diferencia(98, 100, 15, 5) + 2 # Te Quemas + """ + # Realizar la función según la documentación que observáis + + +def obtener_pista(numero: int, numero_oculto: int, intentos: int, frio: int, caliente: int) -> str: + """ + Obtiene una pista combinando la distancia (frío, caliente, te quemas) y si el número oculto + es mayor o menor. + + Args: + numero (int): Número ingresado por el usuario. + numero_oculto (int): Número que debe ser adivinado. + intentos (int): Cantidad de intentos restantes. + frio (int): Diferencia máxima para considerar la pista como "Frío". + caliente (int): Diferencia máxima para considerar la pista como "Caliente". + + Returns: + str: Frase con la pista para el juego. + + Note: + La función retorna uno de los siguientes mensajes según la proximidad del número ingresado al número oculto: + + - "* FRÍO, FRÍO, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* FRÍO, FRÍO, el número oculto es MAYOR... ¡te quedan N intentos!\n" + - "* CALIENTE, CALIENTE, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* CALIENTE, CALIENTE, el número oculto es MAYOR... ¡te quedan N intentos!\n" + - "* TE QUEMAS, el número oculto es MENOR... ¡te quedan N intentos!\n" + - "* TE QUEMAS, el número oculto es MAYOR... ¡te quedan N intentos!\n" + + En los mensajes, "N" representa el número de intentos restantes. + """ + # Realizar la función según la documentación que observáis + # Daros cuenta que debéis hacer una llamada a la función evaluar_diferencia() + + +def pedir_numero_usuario(mensaje: str, minimo: int = None, maximo: int = None) -> int: + """ + Solicita al usuario que introduzca un número entero válido. + + Args: + mensaje (str): Mensaje que se muestra al usuario para pedir el número. + + Returns: + int: Número entero ingresado por el usuario. + + Raises: + ValueError: Si el valor introducido no puede convertirse a un número entero. + """ + # El código de esta función NO SE PUEDE TOCAR! Ya está terminada + try: + num = int(input(mensaje).strip()) + except ValueError: + raise ValueError("El número introducido no es un entero válido!") + + if minimo != None and num < minimo: + raise ValueError(f"El número introducido no es correcto (mínimo: {minimo})") + + if maximo != None and num > maximo: + raise ValueError(f"El número introducido no es correcto (máximo: {maximo})") + + return num + + +def adivina_el_numero(numero_oculto: int, total_intentos: int, minimo: int, maximo: int, frio: int, caliente: int): + """ + Gestiona el proceso de adivinación del número oculto, permitiendo que el usuario ingrese números. + + Args: + numero_oculto (int): Número que debe ser adivinado. + total_intentos (int): Cantidad total de intentos permitidos. + minimo (int): Número mínimo que puede alcanzar el número oculto. + maximo (int): Número máximo que puede alcanzar el número oculto. + frio (int): Diferencia máxima para considerar la pista como "Frío". + caliente (int): Diferencia máxima para considerar la pista como "Caliente". + + Returns: + tuple: Un booleano que indica si el número fue adivinado y el número de intentos realizados. + """ + # Hacer un bucle hasta que se adivine el número o realice todos los intentos posibles... + # Utiliza pedir_numero_usuario("¿Qué número es? ", minimo, maximo) + # Muestra la pista con obtener_pista() si el número introducido no es el oculto (obtener_pista()). + # La función debe retornar si el número fue adivinado y los intentos realizados. + + + return numero_adivinado, intentos_realizados + + +def configurar_rangos_numeros() -> tuple: + """ + Configura el rango de números válidos para el juego solicitando los valores mínimo y máximo. + + Returns: + tuple: Una tupla que contiene el número mínimo y el número máximo configurados para el juego. + + Raises: + ValueError: Si el valor mínimo es superior al máximo o si la diferencia entre el máximo y + el mínimo es menor a 100. + """ + # Debe usar pedir_numero_usuario() para solicitar el número mínimo y máximo del + # rango posible para el número oculto. + # Requisitos que debe cumplir para aceptar el mínimo y máximo: + # 1. El número mínimo debe ser menor que el máximo. + # (*ERROR* El valor mínimo no puede ser superior al máximo.) + # 2. La diferencia entre ambos debe ser igual o superior a 100. + # (*ERROR* El rango del número oculto debe ser igual o superior a 100.) + + return minimo, maximo + + +def configurar_pistas(minimo: int, maximo: int) -> tuple: + """ + Configura los valores de diferencia para las pistas "Frío" y "Caliente". + + Args: + minimo (int): El número mínimo dentro del rango de juego. + maximo (int): El número máximo dentro del rango de juego. + + Returns: + tuple: Una tupla que contiene los valores para las pistas de "Frío" y "Caliente". + + Raises: + ValueError: Si la diferencia para la pista "Frío" no es mayor que la de "Caliente", + si "Caliente" es menor o igual a 0, o si alguno de los valores se sale + del rango (minimo, maximo). + """ + # Debe usar pedir_numero_usuario() para solicitar los valores de diferencia + # para las pistas "Frío" y "Caliente". + # Requisitos que debe cumplir para aceptar estos valores: + # 1. La diferencia para la pista FRÍO no puede ser inferior o igual a la CALIENTE. + # (*ERROR* La diferencia para la pista FRÍO no puede ser inferior o igual a la CALIENTE!) + # 2. La diferencia para la pista CALIENTE debe ser superior a 0. + # (*ERROR* La diferencia para la pista CALIENTE debe ser superior a 0!) + # 3. La diferencia para la pista FRÍO debe estar entre minimo y maximo. + # (*ERROR* La diferencia para la pista FRÍO debe estar entre {minimo} y {maximo}!) + # 4. La diferencia para la pista CALIENTE debe estar entre minimo y maximo. + # (*ERROR* La diferencia para la pista CALIENTE debe estar entre {minimo} y {maximo}!) + + return frio, caliente + + +def configurar_intentos(rango_numero_oculto) -> int: + """ + Configura el número de intentos para adivinar el número oculto, asegurando que el valor es positivo + y no excede el 10% del rango de números. + + Args: + rango_numero_oculto (int): El rango del número oculto (diferencia entre el máximo y el mínimo). + + Returns: + int: El número de intentos configurado por el usuario. + + Raises: + ValueError: Si el número de intentos es menor o igual a 0 o si excede el 10% del rango. + """ + # Debe usar pedir_numero_usuario() para solicitar los intentos posibles. + # Requisitos que debe cumplir para aceptar el valor: + # 1. Número entero positivo mayor que cero. + # (*ERROR* El número de intentos debe ser un número entero positivo!) + # 2. Inferior al 10% del rango del número oculto. + # (*ERROR* El número de intentos no puede ser superior al 10% del rango del número oculto!) + + return intentos + + +def configurar_juego() -> tuple: + """ + Configura todos los parámetros del juego: rango de números, pistas e intentos. + + Returns: + tuple: Mínimo, máximo, número de intentos, valor para "Frío" y valor para "Caliente". + """ + # Completar la llamada a las funciones correctas... + limpiar_pantalla() + mostrar_titulo(4) + + minimo, maximo = + frio, caliente = + intentos = + + return minimo, maximo, intentos, frio, caliente + + +def mostrar_configuracion(minimo, maximo, intentos, frio, caliente): + """ + Muestra la configuración actual del juego. + + Args: + minimo (int): Mínimo número del rango. + maximo (int): Máximo número del rango. + intentos (int): Número de intentos posibles. + frio (int): Diferencia mayor para la pista "Frío". + caliente (int): Diferencia mayor para la pista "Caliente". + """ + # Corregir posibles errores... + limpiar_pantalla + mostrar_titulo() + print("* El número oculto será un número entre {minimo} y {maximo}.") + print("* El número de intentos es {intentos}.") + print("* Pista FRÍO si la diferencia es mayor a {frio}.") + print("* Pista CALIENTE si la diferencia es mayor a {caliente}.") + print("* Pista TE QUEMAS si la diferencia es menor.") + pausa + + +def mostrar_menu(): + """ + Muestra el menú principal del juego. + """ + # Corregir posibles errores... + mostrar_titulo() + input("1. Jugar.") + input("2. Configurar.") + input("3. Mostrar configuración.") + input("4. Salir.\n") + limpiar_pantalla() + + +def comprobar_opcion() + # Crear la documentación recomendada para esta función + return 1 <= opcion <= 4 + + +def elegir_opcion_menu() -> int: + """ + Permite al usuario elegir una opción del menú. + + Returns: + int: La opción elegida por el usuario. + """ + # Corregir posibles errores... + opcion_correcta = False + + while not opcion_correcta: + mostrar_menu() + + opcion = pedir_numero_usuario("Elije => ") + + opcion_correcta = comprobar_opcion(opcion) + + if not opcion_correcta: + mostrar_error(f"Opción {opcion} incorrecta! (1-4)") + + + +def jugar(numero_oculto: int, intentos: int, frio: int, caliente: int): + """ + Gestiona el proceso del juego de adivinar el número oculto y muestra los resultados al finalizar. + + Args: + numero_oculto (int): Número que debe ser adivinado por el jugador. + minimo (int): El límite inferior del rango de números posibles. + maximo (int): El límite superior del rango de números posibles. + intentos (int): Número máximo de intentos permitidos para el jugador. + frio (int): Diferencia mínima para que se active la pista "Frío". + caliente (int): Diferencia mínima para que se active la pista "Caliente". + + Note: + - Un mensaje de éxito si el jugador adivina el número, indicando los intentos utilizados. + - Un mensaje de fin de juego si el jugador no logra adivinar el número, mostrando el número oculto. + """ + # Mostrar el mensaje correspondiente al final del juego: + # - Si lo adivinó => "\n¡Bravo! ¡Lo conseguiste en N intentos!" + # - Si no lo consiguió => "\nGAME OVER - ¡Otra vez será! (#XX#)" + # Donde N es el númnero de intentos en el que consiguió acertarlo y XX el número oculto. + # Recuerda que debes mostrar dichos mensajes hasta que el usuario presione ENTER... + # También debes corregir posibles errores... + limpiar_pantalla() + mostrar_titulo(3, intentos) + numero_adivinado, intentos_realizados = adivina_el_numero(numero_oculto, intentos, frio, caliente) + + pausa + + +def genera_numero_oculto(minimo: int, maximo: int) -> int: + """ + Genera un número oculto aleatorio dentro de un rango determinado. + + Args: + minimo (int): El valor mínimo posible. + maximo (int): El valor máximo posible. + + Returns: + int: Número generado aleatoriamente entre mínimo y máximo. + """ + return random.randint(minimo, maximo) + + +def main(): + """ + Función principal que ejecuta el flujo completo del juego de adivinar el número oculto. + + Configura los parámetros iniciales, muestra la configuración actual, y gestiona el bucle principal del menú + para permitir al usuario jugar, configurar el juego, mostrar la configuración actual del juego o salir. + + Note: + 1. Limpia la pantalla, muestra el título de bienvenida y hace una pausa inicial. + 2. Configura los parámetros iniciales del juego: + - minimo: Límite inferior del rango de números (por defecto 0). + - maximo: Límite superior del rango de números (por defecto 100). + - frio: Diferencia mínima para la pista "Frío" (por defecto 15). + - caliente: Diferencia mínima para la pista "Caliente" (por defecto 5). + - intentos: Número máximo de intentos (por defecto 5). + 3. Muestra la configuración actual del juego y pide presionar una tecla para continuar... + 4. Permite al usuario interactuar mediante un menú: + - Opción 1: Jugar e intentar adivinar el número oculto. + - Opción 2: Configurar los parámetros del juego. + - Opción 3: Visualizar la configuración actual del juego. + - Opción 4: Salir del juego. + 5. Finaliza el juego mostrando un mensaje de despedida. + """ + # Debe limpiar la pantalla, mostrar el título de la sección correspondiente y hacer una pausa de 2 segundos + # Corrige los posibles errores... + + minimo = 0 + maximo = 100 + frio = 15 + caliente = 5 + intentos = 5 + + mostrar_configuracion() + + salir = False + + while salir: + opcion = elegir_opcion_menu() + + if opcion == 1: + numero_oculto = genera_numero_oculto() + jugar(numero_oculto, intentos, frio, caliente) + elif opcion == 2: + minimo, maximo, intentos, frio, caliente = configurar_juego + elif opcion == 3: + mostrar_configuracion() + else: + salir = True + + limpiar_pantalla() + print("Bye, bye...\n\n") + + +if __name__ == "__main__": + main()