算法训练第八天

344.反转字符串

思路:

我们用双指针来解,i指向开头,j指向结尾,当i小于j时,每次交换s[i],s[j]即可。

代码:

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

541.反转字符串II

思路:

因为python中的字符串是不可变类型,因此我们需要将字符串转为字符数组,然后再进行修改。我们使用双指针和滑动窗口算法,使用i指向滑动窗口的起始位置,j指向滑动窗口的最后一个元素,然后反转。只是最后需要判断结束循环时滑动窗口的状态。

代码:

python 复制代码
class Solution(object):
    def reverse_str(self,s,left,right):
        i = left
        j = right
        while i<j:
            s[i],s[j] = s[j],s[i]
            i+=1
            j-=1
    def reverseStr(self, s, k):
        """
        :type s: str
        :type k: int
        :rtype: str
        """
        i = 0
        j = 0
        str = list(s)
        while j < len(str)-1:
            while j - i + 1 < 2 * k and j < len(str)-1:
                j += 1
            if j==len(str)-1:
                break
            self.reverse_str(str, i, i + k - 1)
            i = j + 1
            j += 1
        if j-i+1<k:
            self.reverse_str(str,i,j)
        else:
            self.reverse_str(str, i, i + k - 1)
        ans = "".join(str)
        return ans

54.替换数字

思路:

我们使用的是python,因此必须要开一个辅助数组,那这样就很简单了,我们只需要遍历字符串放入数组,如果是数字,就放入一个number就好了。

代码:

python 复制代码
def main(s):
    str = list(s)
    new_str = []
    for i in str:
        if ord(i)>=ord('0') and ord(i)<=ord('9'):
            new_str.append('number')
        else:
            new_str.append(i)
    print(''.join(new_str))
 
if __name__=='__main__':
    s = input()
    main(s)
相关推荐
Jasmine_llq10 小时前
《P3825 [NOI2017] 游戏》
算法·游戏·枚举法·2-sat 算法·tarjan 算法·邻接表存储
Miraitowa_cheems11 小时前
LeetCode算法日记 - Day 38: 二叉树的锯齿形层序遍历、二叉树最大宽度
java·linux·运维·算法·leetcode·链表·职场和发展
wangzy198211 小时前
图形基础算法:如何将点与带曲线边的多边形位置关系算法做稳定
算法
艾醒11 小时前
探索大语言模型(LLM):Ollama快速安装部署及使用(含Linux环境下离线安装)
人工智能·深度学习·算法
艾醒11 小时前
探索大语言模型(LLM):Open-WebUI的安装
人工智能·算法·全栈
猫天意12 小时前
【CVPR2023】奔跑而非行走:追求更高FLOPS以实现更快神经网络
人工智能·深度学习·神经网络·算法·机器学习·卷积神经网络
宁檬精12 小时前
算法练习——55.跳跃游戏
数据结构·算法·游戏
王璐WL12 小时前
【C语言入门级教学】内存函数
c语言·开发语言·算法
啃啃大瓜12 小时前
python常量变量运算符
开发语言·python·算法
熊文豪12 小时前
【华为OD】找出通过车辆最多颜色
算法·华为od