Answers:
你可以做:
>>> 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'
Python函数sorted
返回基于ASCII的字符串结果。
不正确:在下面的例子中,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'
该代码可用于按字母顺序对字符串进行排序,而无需使用python的任何内置函数
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()函数的答案。这是使用accumulate()对字符串排序的另一种方法。
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','iiiimppsss ','iiiimppssss')
我们正在选择元组的最后一个索引(-1)
sorted(a)
将返回一个排序列表,因此您不需要进行字符串比较join()
(请参见下面的askewchan答案)。