344、反转字符串
public void reverseString(char[] s) {
int left = 0, right = s.length - 1;
while (left < right) {
char temp = s[left];
s[left] = s[right];
s[right] = temp;
left++;
right--;
}
}
541、反转字符串II
public String reverseStr(String s, int k) {
char[] array = s.toCharArray();
for (int i = 0; i < array.length; i += 2 * k) {
int left = i, right = Math.min(array.length - 1, left + k - 1);
while (left < right) {
char temp = array[left];
array[left] = array[right];
array[right] = temp;
left++;
right--;
}
}
return new String(array);
}
重点和精髓在于 for 循环的取值变化,利用 i 的递进规则进行分段
附加54、替换数字
题目链接:链接
public static String replaceNumber(String s) {
char[] array = s.toCharArray();
StringBuilder sb = new StringBuilder();
for (char c : array) {
if ('0' <= c && c <= '9') {
sb.append("number");
} else {
sb.append(c);
}
}
return sb.toString();
}
如果是实际应用的背景下,可能这个更简单易懂