题解 | #字符串排序#

字符串排序

https://www.nowcoder.com/practice/5190a1db6f4f4ddb92fd9c365c944584

s = input()
al = []

for i in s:#遍历输入的字符串,如果当前字符是字母,则加入到字母列表中
    if i.isalpha():
        al.append(i)

def tr(a):#定义子函数tr,将输入的大写字母转换为小写
    if (a >= 'A' and a <= 'Z'):
        return chr(ord(a) - ord('A') + ord('a'))
    else:
        return a

al.sort(key = tr)#以子函数tr为关键字,对字母列表进行升序排列

j = 0
for i in s:#遍历输入的字符串,如果当前字符是字母,则不换行输出一个字母列表中的元素,否则不换行输出当前字符
    if i.isalpha():
        print(al[j], end = '')
        j += 1
    else:
        print(i, end = '')

#华为机试#
全部评论

相关推荐

Yki_:你要算时间成本呀,研究生两三年,博士三四年,加起来就五六年了,如果你本科去腾讯干五年,多领五年的年薪,加上公司内涨薪,可能到时候十五年总薪资也跟博士差不多
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务