题解 | #字符串排序#

字符串排序

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

# 接受输入
code = input() 

# 提取并且整理字母(无视大小写)
alpha_chars = sorted([c for c in code if c.isalpha()], key=str.lower)

# 将整理之后的字母重新放回原string中
result = []
j = 0  # Pointer to track position in sorted alphabetical characters

for n in code:
    # 如果character是字母,将它替代为整理后的字母
    if n.isalpha():
        result.append(alpha_chars[j])
        j += 1  # j+1确保可以开始检查下一个整理过的字母
    else:
        #  如果不是字母,保留原character位置不变
        result.append(n)

# join整个list到最终的整理后list中
print("".join(result))

全部评论

相关推荐

05-09 13:22
门头沟学院 Java
点赞 评论 收藏
分享
代码飞升:别用口语,后端就写后端,前端就写前端,最后别光后悔
点赞 评论 收藏
分享
本神尊:看来是没招到小红薯上的人
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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