双指针技巧--翻转字符串
- leetcode 344题 翻转字符串
- 题目描述
- 解题思路
- 代码演示
leetcode 344题 翻转字符串
leetcode 344 题 原题链接
https://leetcode.cn/problems/reverse-string/
题目描述
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
示例:
输入:s = [“h”,“e”,“l”,“l”,“o”]
输出:[“o”,“l”,“l”,“e”,“h”]
解题思路
双指针技巧:
一个指针在数组左边,一个在数组右边
然后左右数组元素交换
左边指针右移
右边指针左移
代码演示
public void reverseString(char[] s) {if(null == s || s.length < 2){return;}int i = 0; int j = s.length - 1;while(i < j ){swap(s,i,j);i++;j--; }}public void swap(char[]s,int i,int j){char temp = s[i];s[i] = s[j];s[j] = temp;}
双指针技巧练习:
双指针技巧-移动零