LeetCode之反转字符串(344)、反转字符串II(541)、整数反转(7)、字符串转换整数(8)

1、反转字符串(344)

题目描述:

【简单题】
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 char[] 的形式给出。

不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

你可以假设数组中的所有字符都是 ASCII 码表中的可打印字符。

在这里插入图片描述
题目链接

思路分析

要求:反转即倒序输出
约束:原地修改

题解一:字符串的反转函数

class Solution:
    def reverseString(self, s: List[str]) -> None:
        """
        Do not return anything, modify s in-place instead.
        """
        s.reverse()
  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度: O ( 1 ) O(1) O(1)

题解二:双指针法

\quad \quad 左右开工,两侧相对应的位置相互交换,然后移动指针即可(左指针加一,右指针减一)。

class Solution:
    def reverseString(self, s: List[str]) -> None:
        """
        Do not return anything, modify s in-place instead.
        """
        i,j=0,len(s)-1
        while i<j:
            s[i],s[j]=s[j],s[i]
            i+=1
            j-=1
  • 时间复杂度: O ( N ) O(N) O(N),进行了 N / 2 N/2 N/2次的交换
  • 空间复杂度: O ( 1 ) O(1) O(1)

2、反转字符串II(541)

题目描述:

【简单题】

给定一个字符串 s 和一个整数 k,你需要对从字符串开头算起的每隔 2k 个字符的前 k 个字符进行反转。

  • 如果剩余字符少于 k 个,则将剩余字符全部反转。

  • 如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。

    在这里插入图片描述

题目链接
思路分析

要求:每隔 2k 个字符,则反转前k个字符。
约束:两个如果

题解一:

\quad \quad 每隔 2k 个字符,相当于以步长为2k ,遍历整个字符串;反转前k个字符,我们可以仅将前k个字符反转,其余保持不变,特殊情况也满足这样的情况。

class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        a=list(s)
        for i in range(0,len(a),2*k):
            a[i:i+k]=reversed(a[i:i+k])
        return "".join(a)#将列表转换为字符串
  • 时间复杂度: O ( N ) O(N) O(N),N是字符串的长度。
  • 空间复杂度: O ( N ) O(N) O(N),建立了一个辅助列表

题解二:

\quad \quad 每隔 2k 个字符,则反转前k个字符;相当于依次前进k个字符,依次反转和不反转。可设置一个反转标志flag,依次迭代为反转和不反转。

class Solution:
    def reverseStr(self, s: str, k: int) -> str:
        result,flag="",True
        for i in range(0,len(s),k):
            result+=s[i:i+k][::-1] if flag else s[i:i+k]
            flag=not flag
        return result
  • 时间复杂度: O ( N ) O(N) O(N),N是字符串的长度。
  • 空间复杂度: O ( N ) O(N) O(N),建立了一个辅助列表

3、整数反转(7)

题目描述:

【简单题】
给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
在这里插入图片描述
题目链接

思路分析

4、字符串转换整数(8)

题目描述:

【中等题】

请你来实现一个 atoi 函数,使其能将字符串转换成整数。

首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。接下来的转化规则如下:

  • 如果第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字字符组合起来,形成一个有符号整数。
  • 假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成一个整数。
  • 该字符串在有效的整数部分之后也可能会存在多余的字符,那么这些字符可以被忽略,它们对函数不应该造成影响。

注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换,即无法进行有效转换。

在任何情况下,若函数不能进行有效的转换时,请返回 0 。

提示:

  • 本题中的空白字符只包括空格字符 ’ ’ 。
  • 假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231, 231 − 1]。如果数值超过这个范围,请返回 INT_MAX (231 − 1) 或 INT_MIN (−231) 。

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值