编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s
的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
class Solution {
public void reverseString(char[] s) {
int n = s.length;
for (int left = 0, right = n - 1; left < right; ++left, --right) {
char temp = s[left];
s[left] = s[right];
s[right] = temp;
}
//观察反转前和反转后的数组下标。i为数组的下标,n为数组长度。
//可以发现规律:前-> s[i] 后->s[n-1-i] ==>s[i] = s[n-1-i]
//当left < right 为false,表示全部翻转完成。
//一共执行了 n/2 次交换。
}
}
复杂度分析
- 时间复杂度:O(N),其中 N 为字符数组的长度。一共执行了 N/2 次的交换。
- 空间复杂度:O(1)。只使用了常数空间来存放若干变量。