@snuffles
2019-04-11T02:35:07.000000Z
字数 568
阅读 1068
字符串
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 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++;}}
