【数据结构与算法】力扣 344. 反转字符串

题目描述

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。

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

示例 1:

复制代码
输入: s = ["h","e","l","l","o"]
输出: ["o","l","l","e","h"]

示例 2:

复制代码
输入: s = ["H","a","n","n","a","h"]
输出: ["h","a","n","n","a","H"]

提示:

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

分析解答

题目不让使用额外的数组分配空间,只能原地操作。

那就要双指针交换了。来呗,弄!😎

js 复制代码
/**
 * @param {character[]} s
 * @return {void} Do not return anything, modify s in-place instead.
 */
var reverseString = function (s) {
    let l = 0
    let r = s.length - 1
    while (l < r) {
        [s[l], s[r]] = [s[r], s[l]]
        l++
        r--
    }
};

思路拓展

相关推荐
断剑zou天涯2 小时前
【算法笔记】窗口内最大值或最小值的更新结构
java·笔记·算法
smj2302_796826522 小时前
解决leetcode第3753题范围内总波动值II
python·算法·leetcode
骑着猪去兜风.4 小时前
线段树(二)
数据结构·算法
fengfuyao9855 小时前
竞争性自适应重加权算法(CARS)的MATLAB实现
算法
散峰而望5 小时前
C++数组(二)(算法竞赛)
开发语言·c++·算法·github
leoufung5 小时前
LeetCode 92 反转链表 II 全流程详解
算法·leetcode·链表
wyhwust6 小时前
交换排序法&冒泡排序法& 选择排序法&插入排序的算法步骤
数据结构·算法·排序算法
利刃大大6 小时前
【动态规划:背包问题】完全平方数
c++·算法·动态规划·背包问题·完全背包
wyhwust6 小时前
数组----插入一个数到有序数列中
java·数据结构·算法
im_AMBER6 小时前
Leetcode 59 二分搜索
数据结构·笔记·学习·算法·leetcode