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))
相关推荐
并不喜欢吃鱼16 分钟前
从零开始 C++-----十一【C++ 数据结构】红黑树全解析:从定义到工程实现(一文搞定,十分详细)
开发语言·数据结构·c++
星恒随风16 分钟前
C语言数据结构排序算法详解(上):从插入排序、希尔排序到选择排序、堆排序
c语言·数据结构·笔记·学习·排序算法
迈巴赫车主19 分钟前
蓝桥杯21247弹跳鞋java
java·开发语言·数据结构·算法·职场和发展·蓝桥杯
Cthy_hy1 小时前
Python算法竞赛:集合去重+字典映射 核心用法一站式整理
数据结构·python·算法
happymaker06261 小时前
LeetCodeHot100——盛水最多的容器
数据结构·算法·leetcode·双指针·hot100
过期动态1 小时前
【LeetCode 热题 100】三数之和
java·数据结构·算法·leetcode·职场和发展·排序算法
一切皆是因缘际会1 小时前
AI高速迭代下的技术风险与理性突围
大数据·数据结构·人工智能·架构
代码中介商2 小时前
B+树:数据库索引的终极奥秘
数据结构
蓝速科技2 小时前
3D 数字人全息舱算力部署方案对比:本地 X86 独显架构与云端 RK 架构怎么选才好
数据结构·人工智能·算法·架构·排序算法
福大大架构师每日一题2 小时前
redis 8.8.0 发布:新数据结构、字段级通知、INCREX、XNACK 全面升级,8.6 到 8.8 变化一文看懂
数据结构·数据库·redis