@snuffles
2019-04-11T02:35:07.000000Z
字数 568
阅读 813
字符串
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 char[] 的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
你可以假设数组中的所有字符都是 ASCII 码表中的可打印字符。
示例 1:
输入:["h","e","l","l","o"]
输出:["o","l","l","e","h"]
解:从两头往中间走
void reverseString(vector<char>& s) {
int left=0,right=s.size()-1;
while(left<right){
swap(s[left++],s[right--]);
}
}
void reverseString(vector<char>& s) {
int len = s.size();
int i=0;
int count = len/2;
while(count--){
swap(s[i],s[len-1-i]);
i++;
}
}
void reverseString(vector<char>& s) {
char tmp;
int size = s.size();
int loop = 0;
while( loop < size/2){
tmp = s[loop];
s[loop] = s[size - 1 - loop];
s[size - 1- loop] = tmp;
loop++;
}
}