代码随想录算法训练营第八天 | 反转字符串、 反转字符串II 、替换空格、翻转字符串里的单词、左旋转字符串

344. 反转字符串

思路:双指针,分别从头尾开始,向中间移动,每次都将所指元素进行交换

class Solution:
    def reverseString(self, s: List[str]) -> None:
        """
        Do not return anything, modify s in-place instead.
        """
        n = len(s)
        i, j = 0, n - 1
        while i < j:
            s[i], s[j] = s[j], s[i]
            i += 1
            j -= 1
        return

541. 反转字符串 II

笔记:python中不会有超出数组的问题,直接反转就可以

代码:

class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        def reverse(text):
            i = 0
            j = len(text) - 1
            while i < j:
                text[i], text[j] = text[j], text[i]
                i += 1
                j -= 1
            return text
        res = list(s)
        n = len(s)
        for i in range(0, n, 2*k):
            res[i : i + k] = reverse(res[i : i + k])
        return ''.join(res)

剑指 Offer 05. 替换空格

class Solution:
    def replaceSpace(self, s: str) -> str:
        counter = s. count(' ')
        res = list(s)
        res.extend([' '] * counter * 2)
        l, r = len(s) - 1, len(res) - 1
        while l >= 0:
            if res[l] != ' ':
                res[r] = res[l]
                r -= 1
            else:
                res[r] = '0'
                res[r - 1] = '2'
                res[r - 2] = '%'
                r -= 3
            l -= 1
        return ''.join(res)

151. 反转字符串中的单词

思路:先去除多余空格,再翻转整个字符串,再分别翻转每个单词

剑指 Offer 58 - II. 左旋转字符串

思路:

  1. 反转区间为前n的子串
  2. 反转区间为n到末尾的子串
  3. 反转整个字符串
class Solution:
    def reverseLeftWords(self, s: str, n: int) -> str:
        s = list(s)
        s[0:n] = list(reversed(s[0:n]))
        s[n:] = list(reversed(s[n:]))
        s.reverse()
        return ''.join(s)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值