牛客网学习笔记——中等题们(字符串)

HJ27 查找兄弟单词

在这里插入图片描述
在这里插入图片描述

l = list(input().split())
list = l[1:-2]
k = int(l[-1])
k2 = l[-2]
re = []
for i in range(len(list)):
    if list[i] == k2 or len(k2) != len(list[i]):
        continue
    elif sorted(list[i]) == sorted(k2):
        re.append(list[i])
print(len(re))
re.sort()
if len(re) > k-1:
    print(re[k-1])

HJ29 字符串加解密

在这里插入图片描述
在这里插入图片描述
又来展示智商下限了,我写的:

def zip(s):
    re = ''
    for i in range(len(s)):
        if 'a'<= s[i] < 'z':
            re += chr(ord(s[i]) + ord('B') - ord('a'))
        elif s[i] == 'z':
            re += 'A'
        elif 'A'<= s[i] < 'Z':
            re += chr(ord(s[i]) + ord('b') - ord('A'))
        elif s[i] == 'Z':
            re += 'a'
        elif '0' <= s[i] < '9':
            re += str(int(s[i])+1)
        elif s[i] == '9':
            re += '0'
    return re
def unzip(s):
    re = ''
    for i in range(len(s)):
        if 'a'< s[i] <= 'z':
            re += chr(ord(s[i]) + ord('A') - ord('b'))
        elif s[i] == 'a':
            re += 'Z'
        elif 'A'< s[i] <= 'Z':
            re += chr(ord(s[i]) + ord('a') - ord('B'))
        elif s[i] == 'A':
            re += 'z'
        elif '0' < s[i] <= '9':
            re += str(int(s[i])-1)
        elif s[i] == '0':
            re += '9'
        else:
            re += s[i]
    return re
s1 = input()
s2 = input()
print(zip(s1))
print(unzip(s2))
正常人写的
def check(a,b):
    L1 = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
    L2 = "BCDEFGHIJKLMNOPQRSTUVWXYZAbcdefghijklmnopqrstuvwxyza1234567890"
    result = ""
    if b == 1:
        for i in a:
            result += L2[L1.index(i)]
    elif b == -1:
        for i in a:
            result += L1[L2.index(i)]
    return result
while True:
    try:
        print(check(input(),1))
        print(check(input(), -1))
 
    except:
        break

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python学习笔记|字符串与正则表达式练习答案 1. 练习1: 目:给定一个字符串s,找出其中的连续的最长的数字串。 答案:可以通过正则表达式来匹配数字串,然后使用max函数找出最长的。 代码示例: import re def find_longest_num_str(s): num_str_list = re.findall('\d+', s) longest_str = max(num_str_list, key=len) return longest_str s = "ab1234c56789def" print(find_longest_num_str(s)) 输出:56789 2. 练习2: 目:给定一个字符串s,将其中的每个空格替换为"%20"。 答案:可以通过正则表达式的sub函数来实现替换。 代码示例: import re def replace_space(s): new_s = re.sub(' ', '%20', s) return new_s s = "Hello World" print(replace_space(s)) 输出:Hello%20World 3. 练习3: 目:给定一个字符串s,判断它是否为回文字符串。 答案:可以使用切片操作将字符串反转,然后与原字符串进行比较。 代码示例: def is_palindrome(s): return s == s[::-1] s = "abcba" print(is_palindrome(s)) 输出:True ### 回答2: 以下是关于字符串和正则表达式练习的答案: 1. 给定一个字符串s,编写一个函数,返回该字符串的反转字符串。 def reverse_string(s): return s[::-1] 2. 给定一个字符串s,编写一个函数,返回是否是回文字符串。 def is_palindrome(s): return s == s[::-1] 3. 给定一个字符串s和一个字符c,编写一个函数,返回字符串s中字符c的出现次数。 def count_char(s, c): return s.count(c) 4. 给定一个字符串s,编写一个函数,返回字符串s中的所有单词列表。 def split_words(s): return s.split() 5. 给定一个字符串s,编写一个函数,返回字符串s中的所有数字列表。 import re def extract_numbers(s): return re.findall(r'\d+', s) 这只是一些可能的答案,其中的解决方法可以有很多种。每个问都有不同的解决方案,具体取决于个人的编程风格和需求。希望这些答案能够帮助你理解和学习Python中的字符串和正则表达式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值