Constante de Kaprekar
El matemático indio Dattaraya Ramchandra Kaprekar descubrió en 1949 una curiosa característica del número 6174. Hoy, se conoce a dicho número como constante de Kaprekar en honor a él.
El número es notable por la siguiente propiedad:
- Elige un número de cuatro dígitos que tenga al menos dos diferentes (es válido colocar el dígito 0 al principio, por lo que el número 0009 es válido).
- Coloca sus dígitos en orden ascendente y en orden descendente para formar dos nuevos números. Puedes añadir los dígitos 0 que necesites al principio.
- Resta el menor al mayor.
- Vuelve al paso 2.
A este proceso se le conoce como la rutina de Kaprekar, y siempre llegará al número 6174 en, como mucho, 7 iteraciones. Una vez en él, el proceso no avanzará, dado que 7641 − 1467 = 6174.
Por ejemplo, el número 3524 alcanzará la constante de Kaprekar en 3 iteraciones:
Rutina |
---|
5432 − 2345 = 3087 |
8730 − 0378 = 8352 |
8532 − 2358 = 6174 |
Los únicos dígitos de cuatro cifras para los que la rutina de Kaprekar no alcanza el número 6174 son los repdigits, es decir aquellos cuyas cuatro cifras son iguales (como 1111), pues en la primera iteración se alcanzará el valor 0 y no podrá salirse de él. Es por esto que en el paso 1 se pedía explícitamente que el número inicial tuviera al menos dos dígitos diferentes.
El resto de los números de cuatro cifras terminarán siempre en el número 6174.
A continuación se muestran dos ejemplos más:
- El número 1121 necesita 5 iteraciones:
Rutina |
---|
2111 − 1112 = 0999 |
9990 − 0999 = 8991 |
9981 − 1899 = 8082 |
8820 − 0288 = 8532 |
8532 − 2358 = 6174 |
- El número 1893 necesita 7:
Rutina |
---|
9831 − 1389 = 8442 |
8442 − 2448 = 5994 |
9954 − 4599 = 5355 |
5553 − 3555 = 1998 |
9981 − 1899 = 8082 |
8820 − 0288 = 8532 |
8532 − 2358 = 6174 |
Entrada
La primera línea de la entrada contendrá el número de casos de prueba. Cada uno contendrá, en una única línea, un número a comprobar.
Salida
Para cada caso de prueba, el programa indicará el número de vueltas que se debe dar a la rutina de Kaprekar para alcanzar el 6174. Para los números repdigits deberá escribir 8. Para la propia constante de Kaprekar deberá indicar 0.
Entrada de ejemplo
5
3524
1111
1121
6174
1893
Salida de ejemplo
3
8
5
0
7
Solución propuesta
from functools import reduce
def cadena_a_numero(cadena, revés=False):
lista = sorted([c for c in cadena], reverse=revés)
número = int(reduce(lambda x, y: x + y, lista))
return número
def rellenar_ceros(cadena):
if len(cadena) < 4:
cadena += '0' * (4 - len(cadena))
return cadena
if __name__ == '__main__':
soluciones = []
número_casos = int(input())
for _ in range(número_casos):
número = input()
solución = -1
if número == '6174':
solución = 0
elif reduce(lambda x, y: x and y, list(map(lambda x: número[0] == x, número))):
solución = 8
else:
solución = 0
while número != '6174':
mayor = cadena_a_numero(número, True)
menor = cadena_a_numero(número)
número = rellenar_ceros(str(mayor - menor))
solución += 1
soluciones.append(solución)
for solución in soluciones:
print(solución)