题解 | #字符串排序#

字符串排序

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))

全部评论

相关推荐

你背过凌晨4点的八股文么:简历挂了的话会是流程终止,像我一样
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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