给定一个字符串 S
,返回 “反转后的” 字符串,其中不是字母的字符都保留在原地,而所有字母的位置发生反转。
示例 1:
输入:"ab-cd"
输出:"dc-ba"
示例 2:
输入:"a-bC-dEf-ghIj"
输出:"j-Ih-gfE-dCba"
示例 3:
输入:"Test1ng-Leet=code-Q!"
输出:"Qedo1ct-eeLg=ntse-T!"
提示:
S.length <= 100
33 <= S[i].ASCIIcode <= 122
S
中不包含 \
or "
同时使用两个指针从首部和尾部遍历字符串中的元素:当其中某个指针下标指向的元素不为大/小写字母时,将指针进行推移直到两个指针同时满足条件,则将下标指向的元素进行交换。
代码如下:
class Solution {
public:
string reverseOnlyLetters(string S) {
int i=0,j=S.size()-1;
while(i<=j){
if((S[i]<‘A‘||S[i]>‘Z‘)&&(S[i]<‘a‘ || S[i]>‘z‘)){
i++;
continue;
}
if((S[j]<‘A‘||S[j]>‘Z‘)&&(S[j]<‘a‘ || S[j]>‘z‘)){
j--;
continue;
}
char tmp = S[i];
S[i] = S[j];
S[j] = tmp;
i++;
j--;
}
return S;
}
};
如果使用宏定义isalpha
来判断字符是否为字母,并且使用swap
函数来进行两个字符间的交换,可以使代码更加精简,如下:
class Solution {
public:
string reverseOnlyLetters(string S) {
int i=0,j=S.length()-1;
while(i<j){
if(!isalpha(S[i])){
i++;
continue;
}
if(!isalpha(S[j])){
j--;
continue;
}
swap(S[i],S[j]);
i++;
j--;
}
return S;
}
};
原文:https://www.cnblogs.com/buryinshadow/p/13541908.html