En este post de programación en Python vamos a resolver un ejercicio. Se trata de un problema para saber si un número es Top. El ejercicio dice:
Escriba una función que al recibir un numero entero, verifique que si al sumar las cifras del número y dividirlo por su cantidad de cifras. el resultado es un numero primo. Si es así, se dice que es un numero top. Ej.: 2783 es un número Top, ya que 2+7+8+3=20 / 4 (cifras) = 5, y 5 es primo.
Veamos cómo resolver este ejercicio en Python.
Algoritmo
Lo único que necesitamos es convertir el número a cadena, recorrer las cifras y sumarlas, así como obtener la longitud de la cadena.
Luego, al tener el resultado, comprobamos si el número es primo. Dependiendo de eso, regresamos True
o False
.
Saber si es número top en Python
Comenzamos convirtiendo el número a cadena (así podemos recorrer cada cifra) y calculando su longitud con len
:
numero_cadena = str(numero)
suma_de_cifras = 0
cantidad_cifras = len(numero_cadena)
Ahora hacemos la suma de las cifras y las dividimos entre la longitud:
for cifra in numero_cadena:
suma_de_cifras += int(cifra)
resultado = suma_de_cifras / cantidad_cifras
Finalmente comprobamos si el número es primo:
if primo(resultado):
return True
return False
Ya sé que se podría “optimizar” haciendo un return primo(resultado)
pero quise hacerlo de forma clara.
Poniendo todo junto
El código completo que dice si un número es Top en Python queda así:
"""
https://parzibyte.me/blog
"""
def primo(numero):
if numero == 0 or numero == 1 or numero == 4:
return False
for x in range(2, int(numero/2)):
if numero % x == 0:
return False
return True
def numero_top(numero):
numero_cadena = str(numero)
suma_de_cifras = 0
cantidad_cifras = len(numero_cadena)
for cifra in numero_cadena:
suma_de_cifras += int(cifra)
resultado = suma_de_cifras / cantidad_cifras
if primo(resultado):
return True
return False
# Probar
numero = 2783
resultado = numero_top(numero)
if resultado:
print("Sí es top")
else:
print("NO es top")
Por otro lado, te invito a ver más artículos de programación en Python.