day07-数据结构力扣

344.反转字符串

题目链接344. 反转字符串 - 力扣(LeetCode)

看到这个反转就想直接用库函数

思路

双指针的方法,一个在头,一个在尾,两两交换,再向中间移动。

伪代码

python 复制代码
len=nums.size
for(i=0,j=len-1;i<len/2;i++,j--):
    swap(nums[i],nums[j])

写题

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

541. 反转字符串II

题目链接541. 反转字符串 II - 力扣(LeetCode)

思路

我写了一版,但还是有问题

我的思路是分组,每k个一组,每两组把前面那一组内部交换一次。

写题

错误

**错误1:**忽略str不可约直接修改的问题,把str转为了列表,并且

"b","a","c","d","f","e","g"怎么改成"bacdfeg",用了' '.join(s)

**错误2:**没有处理n<k的情况,后面又单独加上

python 复制代码
class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        n=len(s)
        group_n=n//k
        s=list(s)
        if n<k:
            left=0
            right=n-1
            while(left<n//2):
                s[left],s[right]=s[right],s[left]
                left+=1
                right-=1
        for i in range(0,group_n,2):
            left=i*k
            right=(i+1)*k-1
            while(left-i*k < k//2):
                s[left],s[right]=s[right],s[left]
                left+=1
                right-=1
        return ''.join(s)

但是还是有14个用例不通过

  • 没处理 k ≤ n < 2k 的情况

  • 循环写法虽然能跑,但最后一组可能漏翻转

提交

python 复制代码
class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        s=list(s)
        n=len(s)
        for i in range(0,n,2*k):
            left=i
            right=min(i+k-1,n-1)
            while(left<right):
                s[left],s[right]=s[right],s[left]
                left+=1
                right-=1
        return ''.join(s)

for i in range(0,n,2*k):

  • 每次跳 2k 个字符

  • 完美对应:每 2k 个字符处理一次

right=min(i+k-1,n-1)

  • 如果剩下 ≥k 个字符 → 翻转前 k 个

  • 如果剩下 <k 个字符 → 翻转全部

这两排代码简直是焚诀,将处理过程简化很多,那个right我只会想到写分好几种情况的,不用把这个融合的一起

54.替换数字

题目链接54. 替换数字(第八期模拟笔试)

思路

字符串不能改?换成列表,最后输出再转换一下

遍历每个字符,判断是不是数字,是数字就替换

写题

流下感动的泪水,好久没写过这么简单的题了

python 复制代码
s=input()
s=list(s)
for i in range(len(s)):
    if s[i]>='0' and s[i]<='9':
        s[i]='number'
print(''.join(s))
相关推荐
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠2 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾2 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8212 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q2 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒2 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记2 天前
单项不带头不循环链表
数据结构·链表
小糯米6013 天前
JS 数组
数据结构·算法·排序算法
小欣加油3 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
凌波粒3 天前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode