字符串排序
题目描述
编写一个程序,将输入字符串中的字符按如下规则排序。
规则 1 :英文字母从 A 到 Z 排列,不区分大小写。
如,输入: Type
输出: epTy
规则 2 :同一个英文字母的大小写同时存在时,按照输入顺序排列。
如,输入: BabA
输出: aABb
规则 3 :非英文字母的其它字符保持原来的位置。
如,输入: By?e
输出: Be?y
注意有多组测试数据,即输入有多行,每一行单独处理(换行符隔开的表示不同行)
输入描述:
输入字符串
输出描述:
输出字符串
示例1
输入
A Famous Saying: Much Ado About Nothing (2012/8).
输出
A aaAAbc dFgghh: iimM nNn oooos Sttuuuy (2012/8).
代码
while True:
try:
s = input()
s1 = []
res = [0] * len(s) #用来存放非字母
for i, v in enumerate(s):
if v.isalpha(): #如果是字母,则存在s1列表中
s1.append(v)
else:
res[i] = v #如果是非字母,则存放在res列表中
s1.sort(key=lambda x: x.upper()) #执行排序,这里排序是符合题目条件的:不分大小写排序,如相同字母的大小写同时出现,则按输入先后顺序存放。
for i, v in enumerate(res):
if not v:
res[i] = s1.pop(0)
print(''.join(res))
except:
break