¿Hay una manera fácil de ordenar las letras en una cadena alfabéticamente en Python?
Entonces para:
a = 'ZENOVW'
Me gustaria regresar:
'ENOVWZ'
¿Hay una manera fácil de ordenar las letras en una cadena alfabéticamente en Python?
Entonces para:
a = 'ZENOVW'
Me gustaria regresar:
'ENOVWZ'
Respuestas:
Tu puedes hacer:
>>> a = 'ZENOVW'
>>> ''.join(sorted(a))
'ENOVWZ'
''.join(sorted(a, reverse=True, key=str.lower))
se puede utilizar para realizar una ordenación sin distinción entre mayúsculas y minúsculas. Podría ser útil.
>>> a = 'ZENOVW'
>>> b = sorted(a)
>>> print b
['E', 'N', 'O', 'V', 'W', 'Z']
sorted
devuelve una lista, por lo que puede convertirla en una cadena nuevamente usando join
:
>>> c = ''.join(b)
que une los elementos de b
junto con una cadena vacía ''
entre cada elemento.
>>> print c
'ENOVWZ'
La solución Sorted () puede proporcionarle resultados inesperados con otras cadenas.
Lista de otras soluciones:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower())))
' belou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s)))
' Bbelou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(s))
' BBbbbbeellou'
Si desea deshacerse del espacio en el resultado, agregue la función strip () en cualquiera de los casos mencionados:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower()))).strip()
'belou'
La función Python sorted
devuelve el resultado basado en ASCII para la cadena.
INCORRECTO : en el siguiente ejemplo, e
y d
está detrás H
y W
debido a su valor ASCII.
>>>a = "Hello World!"
>>>"".join(sorted(a))
' !!HWdellloor'
CORRECTO : para escribir la cadena ordenada sin cambiar el caso de la letra. Usa el código:
>>> a = "Hello World!"
>>> "".join(sorted(a,key=lambda x:x.lower()))
' !deHllloorW'
Si desea eliminar todos los signos de puntuación y números. Usa el código:
>>> a = "Hello World!"
>>> "".join(filter(lambda x:x.isalpha(), sorted(a,key=lambda x:x.lower())))
'deHllloorW'
el código se puede usar para ordenar cadenas en orden alfabético sin usar ninguna función incorporada de python
k = input ("Ingrese cualquier cadena nuevamente")
li = []
x = len(k)
for i in range (0,x):
li.append(k[i])
print("List is : ",li)
for i in range(0,x):
for j in range(0,x):
if li[i]<li[j]:
temp = li[i]
li[i]=li[j]
li[j]=temp
j=""
for i in range(0,x):
j = j+li[i]
print("After sorting String is : ",j)
Realmente me gustó la respuesta con la función reduce (). Aquí hay otra forma de ordenar la cadena usando acumular ().
from itertools import accumulate
s = 'mississippi'
print(tuple(accumulate(sorted(s)))[-1])
ordenado (s) -> ['i', 'i', 'i', 'i', 'm', 'p', 'p', 's', 's', 's', 's' ]
tupla (acumular (ordenados) -> ('i', 'ii', 'iii', 'iiii', 'iiiim', 'iiiimp', 'iiiimpp', 'iiiimpps', 'iiiimppss', 'iiiimppsss ',' iiiimppssss ')
Estamos seleccionando el último índice (-1) de la tupla
sorted(a)
devolverá una lista ordenada, por lo que para las comparaciones de cadenas no es necesariojoin()
(consulte las respuestas a continuación).