反转字符串

反转字符串

在这里插入图片描述

def reverseString(s: list[str]) -> None:
    left = 0
    right = len(s) - 1
    for i in range(len(s) // 2):
        s[left],s[right] = s[right],s[left]
        left += 1
        right -= 1
    return s

或者直接 return s.reverse()
要求是在原列表基础上改

反转字符串 Ⅱ

在这里插入图片描述

def reverseStr(s: str, k: int) -> str:
    res = ''
    t = [s[i:i + 2 * k] for i in range(0,len(s),2 * k)]
    print(t)
    for i in range(len(t)):
        t[i] = t[i][:k][::-1] + t[i][k:]
        res += t[i]
    return res

s = "abcdat"
k = 2
print(reverseStr(s,k))

反转字符

在这里插入图片描述

def reverseWords(s: str) -> str:
    t = s.split()[::-1]
    return ''.join(i + ' ' for i in t)[:-1]

s = "the sky is blue"
print(reverseWords(s))

或者:

def reverseWords(s: str) -> str:
    s = s.strip()
    s = s[::-1]
    return ' '.join(word[::-1] for word in s.split())

找出字符串中第一个匹配项的下标

在这里插入图片描述
find量身定做

def strStr(haystack: str, needle: str) -> int:
    return haystack.find(needle)

或者:

def strStr(haystack: str, needle: str) -> int:
    length1 = len(haystack)
    length2 = len(needle)
    for i in range(length1 - length2 + 1):
        if haystack[i] == needle[0]:
            if haystack[i:i + length2] == needle:
                return i
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值