代码随想录算法训练营day8 | 344.反转字符串、541. 反转字符串II、卡码网:54.替换数字、151.翻转字符串里的单词、卡码网:55.右旋转字符串

344.反转字符串

Python的字符串是不可变的,不能原地修改,因此题目给的是列表,在列表中原地修改

python 复制代码
class Solution:
    def reverseString(self, s: List[str]) -> None:
        """
        Do not return anything, modify s in-place instead.
        """
        left = 0
        right = len(s) - 1
        while left < right:
            s[left], s[right] = s[right], s[left]
            left += 1
            right -= 1

541. 反转字符串II

每2*k个字符进行遍历

python 复制代码
class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        s = list(s)
        for i in range(0, len(s), 2*k):
            if i+k <= len(s):
                self.reverse(s, i, i+k-1)
            else:
                self.reverse(s, i, len(s)-1)
        return "".join(s)

    def reverse(self, s, left, right):
        while left < right:
            s[left], s[right] = s[right], s[left]
            left += 1
            right -= 1

卡码网:54.替换数字

将数字替换为number,在C++中字符串是可变的,可以先统计字符串中数字的个数,然后重新开辟空间,从结尾处遍历字符串,遇见数字就填充number

而在python中,字符串是不可变的,想这么做的话可以将字符串转化为list,申请相应的空间,从后向前逐个填充字符。

实际使用Python完成时,转化为list后,不需要申请空间和从后向前填充,而是遇见数字后直接替换为number

python 复制代码
class Solution:
    def change(self, s):
        lst = list(s) # Python里面的string也是不可改的,所以也是需要额外空间的。空间复杂度:O(n)。
        for i in range(len(lst)):
            if lst[i].isdigit():
                lst[i] = "number"
        return ''.join(lst)

151.翻转字符串里的单词

按照Python的做法,直接split,然后反转单词即可

python 复制代码
class Solution:
    def reverseWords(self, s: str) -> str:
        s = s.strip().split()
        s.reverse()
        return " ".join(s)

本着练习的态度:先移除多余空格(使用双指针),再反转整个字符串,最后反转单个单词。有一定难度

python 复制代码
class Solution:
    def reverseWords(self, s: str) -> str:
        # 移除空格
        s = self.removeExtraSpace(s)
        # 反转字符串
        self.reverse(s, 0, len(s)-1)
        # 反转单词
        left = 0
        for i in range(len(s)+1):
            if i == len(s) or s[i] == " ":
                self.reverse(s, left, i-1)
                left = i + 1
        return "".join(s)

    def removeExtraSpace(self, s):
        s = list(s)
        slow = 0
        i = 0
        while i < len(s):
            if s[i] != " ":
                if slow != 0:
                    s[slow] = " "
                    slow += 1
                while i < len(s) and s[i] != " ":
                    s[slow] = s[i]
                    slow += 1
                    i += 1
            i += 1
        return s[:slow]

    def reverse(self, s, left, right):
        while left < right:
            s[left], s[right] = s[right], s[left]
            left += 1
            right -= 1

卡码网:55.右旋转字符串

直接将后k个字符与前面的字符拼接,这种方式会用到额外的空间

python 复制代码
k = int(input())
s = input()

#通过切片反转第一段和第二段字符串
#注意:python中字符串是不可变的,所以也需要额外空间
s = s[len(s)-k:] + s[:len(s)-k]
print(s)

先反转字符串,然后反转后的字符串前k个反转,剩下的字符串也反转,即为最终答案

python 复制代码
k = int(input())
s = input()

s = list(s)
s.reverse()
a = s[:k]
b = s[k:len(s)]
a.reverse()
b.reverse()
print("".join(a+b))
相关推荐
算法鑫探4 小时前
闰年判断:C语言实战解析
c语言·数据结构·算法·新人首发
WBluuue4 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌
c++·算法
木子墨5164 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌
EQUINOX15 小时前
2026年码蹄杯 本科院校赛道&青少年挑战赛道提高组初赛(省赛)第一场,个人题解
算法
萝卜小白5 小时前
算法实习Day04-MinerU2.5-pro
人工智能·算法·机器学习
Liangwei Lin6 小时前
洛谷 P3133 [USACO16JAN] Radio Contact G
数据结构·算法
weixin_513449966 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结
c++·人工智能·学习·算法·机器人
code_pgf6 小时前
Qwen2.5-VL 算法解析
人工智能·深度学习·算法·transformer
Code-keys6 小时前
Android Codec2 Filter 算法模块开发指南
android·算法·音视频·视频编解码