【实战】ACM 选手图解 LeetCode 反转字符串

本文是 ACM 选手以图解方式解析 LeetCode 344 反转字符串的问题,通过双指针法详细解释如何原地修改输入数组,实现 O(1) 的额外空间复杂度。强调了不应过度依赖库函数,而应深入理解数据结构和算法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大家好呀,我是反转蛋。

今天是反转字符串,一道简单到扣脚的题。

简单到什么地步咧?

我看到这么一句话:真是真正意义上能让我重拳出击的第一道题。

不得不说,看到这我还是有受到侮辱的感觉的。

这也太厉害了吧,我重拳出击的第一道题才是“Hello World”。

2fe3a304be64a288e43d42da96cd776

那么,为啥这么简单我还要写这道题呢?

先不告诉你,往下看就完事了。

6c18e0e5be490c8e74abfeea82e4bc3

LeetCode 344:反转字符串

题意

编写一个函数,将输入的字符串反转过来。

示例

输入:s = [“h”, “e”, “l”, “l”, “o”]

输出:[“o”, “l”, “l”, “e”, “h”]

提示

必须原地修改输入数组,使用 O(1) 的额外空间解决这一问题。

  • 1 <= s.length <= 10^5
  • s[i] 都是 ASCII 码表中的可打印字符。

题目解析

水题,难度简单。

就是将 s[0] s[1] … s[n-1] 以 s[n-1] … s[1] s[0] 的形式输出,即 s[i] 和 s[n - i - 1] 交换位置。

那我们可以使用双指针的方式解决这道问题,维护一个左指针 left 和右指针 right。

初始化 left 指向数组首元素,right 指向数组右元素。

当 left < right 的时候,交换 s[left] 和 s[right],同时 left 右移,right 左移。

题目解析说到这,反转字符串不是关键,重要的是我想说…

f038fb1edfadd64eadab56c2c4cf99c

我猜很多小婊贝在做这道题的时候一行代码就解决了这道反转字符串。

毕竟对于想 Python、Java 这种编程语言,是自带很多的库函数,尤其像字符串这种在实际工程中经常要处理的玩意儿,库函数那是数不胜数。

像什么反转字符串,我 Python 直接 reversed 一下多酷多省事,操作多骚,我还用啥双指针,有毛病?

其实这恰恰是我想要

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值