La idea es darse cuenta de que el permutación de un La cadena s
es igual a un conjunto que contiene s
, y una unión establecida de cada subcadena X
de s
con el permu tación de s\X
. Por ejemplo, permute('key')
:
{'key'} # 'key' itself
{'k', 'ey'} # substring 'k' union 1st permutation of 'ey' = {'e, 'y'}
{'k', 'e', 'y'} # substring 'k' union 2nd permutation of 'ey' = {'ey'}
{'ke', 'y'} # substring 'ke' union 1st and only permutation of 'y' = {'y'}
- Unión de 1, 2, 3, y 4, dió todas las permutaciones de la cadena de
key
.
Con esto en mente, un simple algoritmo puede implementarse:
>>> def permute(s):
result = [[s]]
for i in range(1, len(s)):
first = [s[:i]]
rest = s[i:]
for p in permute(rest):
result.append(first + p)
return result
>>> for p in permute('monkey'):
print(p)
['monkey']
['m', 'onkey']
['m', 'o', 'nkey']
['m', 'o', 'n', 'key']
['m', 'o', 'n', 'k', 'ey']
['m', 'o', 'n', 'k', 'e', 'y']
['m', 'o', 'n', 'ke', 'y']
['m', 'o', 'nk', 'ey']
['m', 'o', 'nk', 'e', 'y']
['m', 'o', 'nke', 'y']
['m', 'on', 'key']
['m', 'on', 'k', 'ey']
['m', 'on', 'k', 'e', 'y']
['m', 'on', 'ke', 'y']
['m', 'onk', 'ey']
['m', 'onk', 'e', 'y']
['m', 'onke', 'y']
['mo', 'nkey']
['mo', 'n', 'key']
['mo', 'n', 'k', 'ey']
['mo', 'n', 'k', 'e', 'y']
['mo', 'n', 'ke', 'y']
['mo', 'nk', 'ey']
['mo', 'nk', 'e', 'y']
['mo', 'nke', 'y']
['mon', 'key']
['mon', 'k', 'ey']
['mon', 'k', 'e', 'y']
['mon', 'ke', 'y']
['monk', 'ey']
['monk', 'e', 'y']
['monke', 'y']
Brillante, gracias. – cyrus
Hola, ¿es posible modificar esto para obtener un conteo? Entonces, por ejemplo, ¿es posible obtener un recuento de cuántas subcadenas se le dará una cadena de longitud n? Ejemplo en el que estoy trabajando con la entrada: 31315 (longitud de cadena) dará una salida de 980597910 strings. Solo quiero los números así que tal vez será más fácil y se necesitará menos memoria. – masfenix