代码训练营第八天|344.反转字符串、541. 反转字符串II、卡码网:54.替换数字 、151.翻转字符串里的单词、55.右旋转字符串

一、344.反转字符串

对题目的看法:希望使用双指针对头尾进行交换后返回链表:

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

结果:

 看完卡哥后的想法:卡哥也是想用双指针但用for循环循环n/2次故依旧使用while判断左右大小。

二、541. 反转字符串II

对题目的想法:想用切片解决题目,代码如下:

class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        result = ''
        for i in range(0,len(s),2*k):
            s_1 = s[i:i +k]
            result += s_1[::-1] + s[i +k:i+2*k]
        return result

结果:

 看了卡哥的思路之后:希望用字符串1的思路配合for循环进行求解。有:

class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        def reverseStr_substring(text):
            left ,right = 0 ,len(text)-1
            while left < right:
                temp = text[left]
                text[left] = text[right]
                text[right] = temp

                left += 1
                right -= 1
            return text
        s_1 = list(s)
        for i in range(0,len(s_1),2*k):
            s_1[i:i+k] = reverseStr_substring(s_1[i:i+k])
        
        
        return ''.join(s_1)

三、卡码网:54.替换数字

对题目的想法:由于python无法改变str,故使用遍历替换:

class Solution:
    def change(self, s):
        result = list(s)
        for i in range(len(result)):
            if s[i].isdigit():
                result[i] = 'number'
        return ''.join(result)

 四、151.翻转字符串里的单词

对题目的看法:想用split,再用列表反转后用.join组合。看卡哥后想用时间复杂度为O(n)

class Solution:
    def reverseWords(self, s: str) -> str:
        words = s.split()
        left ,right = 0,len(words)-1
        while left<right:
            words[left], words[right] = words[right], words[left]
            left += 1
            right -= 1
        return " ".join(words)

结果:

 

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

对题目的想法:对题目想要开辟一个新的字符串然后填入,但看卡哥要求后使用切片如下:

k = int(input())
s = input()
s = s[len(s)-k:] + s[:len(s)-k]
print(s)

 总结:双指针在位置替换中经常使用,故在使用时要留意优先使用双指针

  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值