字符串--------》排序、转换

这篇博客探讨了字符串的各种操作,包括按照特定规则排序字符串、单词倒排、字符串合并处理(涉及16进制位反转)、字符串加解密以及字符串通配符匹配。文章提供了题目描述、输入输出示例以及解题方法。
摘要由CSDN通过智能技术生成

字符串排序

题目描述

编写一个程序,将输入字符串中的字符按如下规则排序。
规则 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).

解法1

while True:
    try:
        s = input()
        res,chars = [False]*len(s),[]
        for i,v in enumerate(s):
            if v.isalpha():
                chars.append(v) 
            else:
                res[i] = v
        chars.sort(key=lambda c:c.lower())
        for i,v in enumerate(res):
            if not v:
                res[i] = chars[0]
                chars.pop(0)
        print("".join(res))
    except:
        break

解法2

while True:
    try:
        s = input()
        res,chars = [False]*len(s),""
        for i,v in enumerate(s):
            if v.isalpha():
                chars+=v
            else:
                res[i] = v
        chars = sorted(chars, key=lambda c:c.lower())
        for i,v in enumerate(res):
            if not v:
                res[i] = chars[0]
                chars.pop(0)
        print("".join(res))
    except:
        break

【中级】单词倒排

题目描述

对字符串中的所有单词进行倒排。

说明:

1、构成单词的字符只有26个大写或小写英文字母;

2、非构成单词的字符均视为单词间隔符;

3、要求倒排后的单词间隔符以一个空格表示;如果原字符串中相邻单词间有多个间隔符时,倒排转换后也只允许出现一个空格间隔符;

4、每个单词最长20个字母;

输入描述:

输入一行以空格来分隔的句子

输出描述:

输出句子的逆序

示例1
输入

I am a student

输出

student a am I

拿到题自己以为很简单(实际也不难^_^),自己的解法如下:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值