Python算法--杂乱字符串排序

Python算法--杂乱字符串排序,第1张

题目

编写一个程序,将输入字符串中的字符按如下规则排序。

规则 1 :英文字母从 A 到 Z 排列,不区分大小写。

如,输入: Type 输出: epTy

规则 2 :同一个英文字母的大小写同时存在时,按照输入顺序排列。

如,输入: BabA 输出: aABb

规则 3 :非英文字母的其它字符保持原来的位置。
 

如,输入: By?e 输出: Be?y

例如:

输入:A Famous Saying: Much Ado About Nothing (2012/8).

输出:A aaAAbc dFgghh: iimM nNn oooos Sttuuuy (2012/8).

答案与解析

"""
sorted(iterable,str.upper)就可以实现
1)字符由A到Z的排序
2)能够实现同字母(A与a算同字母),由输入先后书序排列。
str.isalpha()实现的是
如果字符串至少有一个字符并且所有字符都是字母则返回 True,
否则返回 False。
"""
list_s = input()
b = ''
for i in list_s:
    if i.isalpha():
        b += i
s = sorted(b,key=str.upper)
# 将字母挑出来排序后再重新插入到原来的列表里
n = 0
d = ''
for i in list_s:
    if i.isalpha():
        d = d + s[n]
        n += 1
    else:
        d = d + i
print(d)

   

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/732564.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-27
下一篇 2022-04-27

发表评论

登录后才能评论

评论列表(0条)

保存