- 反转字符串 II
给定一个字符串 s 和一个整数 k,从字符串开头算起,每 2k 个字符反转前 k 个字符。
如果剩余字符少于 k 个,则将剩余字符全部反转。 如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。
示例 1: 输入:s = “abcdefg”, k = 2 输出:“bacdfeg”
示例 2: 输入:s = “abcd”, k = 2 输出:“bacd”
提示: 1 <= s.length <= 104 s 仅由小写英文组成 1 <= k <= 104
代码:
class Solution {
public String reverseStr(String s, int k) {
int maxIndex = s.length()-1;
char[] chars = new char[s.length()];
int index = 0;
while (index <= maxIndex){
if (index + k*2 > maxIndex){
if (index+k > maxIndex){
convertChars(s, chars, index, maxIndex);
}else{
convertChars(s, chars, index, index + k-1);
saveChars(s, chars, index+k, maxIndex);
}
break;
}else {
convertChars(s, chars, index, index+k-1);
saveChars(s, chars, index+k, index+2*k);
index = index+2*k;
}
}
return new String(chars);
}
private void convertChars(String s, char[] target, int left, int right){
for (int i = left; i <= right; i++) {
target[right-(i-left)] = s.charAt(i);
}
}
private void saveChars(String s, char[] target, int left, int right){
for (int i = left; i <= right; i++) {
target[i] = s.charAt(i);
}
}
}
|