思路:题目的意思就是每2k个字符进行一次循环访问,如果个数小于k就全部反转,如果大于k则只反转k个字符;
java
class Solution {
public String reverseStr(String s, int k) {
char[] charArray = s.toCharArray();
int length = charArray.length;
//每次2k,2k地访问
for(int i=0;i<length;i+=2*k){
//剩余的长度如果小于k,则剩余的全部交换
if(length-i<k){
revese(charArray,i,length);
}else {
//大于等于k,则只交换到i+k
revese(charArray,i,i+k);
}
}
//字符数组转为String
return new String(charArray);
}
//反转某段数组,左闭右开
private void revese(char[] charArray, int left, int right){
int loop = (right-left)/2;//循环次数,交换次数
right--;//最大下标
while(loop-- > 0){
char temp = charArray[right];
charArray[right--] = charArray[left];
charArray[left++] = temp;
}
}
}