Skip to content

344. 反转字符串

题目链接:https://leetcode.cn/problems/reverse-string/description/

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

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

示例 1:

md

输入:s = ["h","e","l","l","o"]
输出:["o","l","l","e","h"]

示例 2:

md
输入:s = ["H","a","n","n","a","h"]
输出:["h","a","n","n","a","H"]

使用双指针,交换首尾元素,直到两个指针相遇;

若 n 为总长度,s[i]位置的元素和 s[n-i-1]位置的元素交换;

go
func reverseString(s []byte)  {
    // go 中,一个 byte 存储一个 ASCII 字符,一个 rune 存储一个 unicode 字符;
    n := len(s)
    for left,right :=0 ; left < right; left++,right-- {
        s[left],s[right] = s[right],s[left]
    }
}
本站访客数 人次 本站总访问量