翻转字符串
题目
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 char[] 的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
你可以假设数组中的所有字符都是 ASCII 码表中的可打印字符。
具体思路
使用左右指针,分别开始交换。
使用swap()
函数
具体代码
CPP
class Solution {
public:
void reverseString(vector<char>& s) {
//注意要怎么取字符串的长度
for (int i = 0, j = s.size() - 1; i < j; i++, j--) {
swap(s[i], s[j]);
}
}
};
Java
class Solution {
public void reverseString(char[] s) {
int begin = 0;
int end = s.length - 1;
while (begin < end) {
char temp = s[begin];
s[begin] = s[end];
s[end] = temp;
begin++;
end--;
}
}
}