답변:
넌 할 수있어:
>>> a = 'ZENOVW'
>>> ''.join(sorted(a))
'ENOVWZ'
''.join(sorted(a, reverse=True, key=str.lower))
반대의 대소 문자를 구분하지 않는 정렬을 수행 할 수 있습니다. 편리 할 수 있습니다.
Sorted () 솔루션은 다른 문자열로 예기치 않은 결과를 줄 수 있습니다.
다른 솔루션 목록 :
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower())))
' belou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s)))
' Bbelou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(s))
' BBbbbbeellou'
결과에서 공백을 제거하려면 언급 된 경우 strip () 함수를 추가하십시오.
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower()))).strip()
'belou'
파이썬 함수 sorted
는 문자열에 대한 ASCII 기반 결과를 반환합니다.
INCORRECT : 아래의 예에서 e
와 d
뒤에 H
와 W
는 ASCII 값입니다 때문에.
>>>a = "Hello World!"
>>>"".join(sorted(a))
' !!HWdellloor'
수정 : 문자의 대소 문자를 변경 하지 않고 정렬 된 문자열을 작성합니다 . 코드를 사용하십시오 :
>>> a = "Hello World!"
>>> "".join(sorted(a,key=lambda x:x.lower()))
' !deHllloorW'
구두점과 숫자를 모두 삭제하려면 코드를 사용하십시오 :
>>> a = "Hello World!"
>>> "".join(filter(lambda x:x.isalpha(), sorted(a,key=lambda x:x.lower())))
'deHllloorW'
코드는 파이썬의 내장 함수를 사용하지 않고 알파벳 순서로 문자열을 정렬하는 데 사용할 수 있습니다
k = 입력 ( "다시 문자열 입력")
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)
reduce () 함수로 답을 좋아했습니다. 다음은 collect ()를 사용하여 문자열을 정렬하는 다른 방법입니다.
from itertools import accumulate
s = 'mississippi'
print(tuple(accumulate(sorted(s)))[-1])
정렬 됨-> [ 'i', 'i', 'i', 'i', 'm', 'p', 'p', 's', 's', 's', 's' ]
튜플 (누적 (분류)-> ( 'i', 'ii', 'iii', 'iiii', 'iiiim', 'iiiimp', 'iiiimpp', 'iiiimpps', 'iiiimppss', 'iiiimppssss ','iiiimppssss ')
튜플의 마지막 인덱스 (-1)를 선택합니다
sorted(a)
그래서 당신이 필요하지 않은 문자열 비교를 위해, 정렬 된 목록을 반환합니다join()
(askewchan 답은 아래의 참조).