344.反转字符串
题目链接/文章讲解/视频讲解
class Solution {
public void reverseString(char[] s) {
int l = 0;
int r = s.length - 1;
while (l < r) {
s[l] ^= s[r];
s[r] ^= s[l];
s[l] ^= s[r];
l++;
r--;
}
}
}
541. 反转字符串II
题目链接/文章讲解/视频讲解
class Solution {
public String reverseStr(String s, int k) {
StringBuffer res = new StringBuffer();
int start = 0;
int length = s.length();
while (start < length) {
StringBuffer tmp = new StringBuffer();
int firstK = (start + k > length) ? length : start + k;
int secondK = (start + 2 * k > length) ? length : start + 2 * k;
tmp.append(s.substring(start, firstK));
res.append(tmp.reverse());
if (firstK < secondK) {
res.append(s.substring(firstK, secondK));
}
start += (2 * k);
}
return res.toString();
}
}
卡码网:54.替换数字
题目链接/文章讲解/视频讲解
import java.util.Scanner;
public class Main {
public static String replaceNumbersWithText(String s) {
StringBuilder result = new StringBuilder();
for (char c : s.toCharArray()) {
if (Character.isDigit(c)) {
result.append("number");
} else {
result.append(c);
}
}
return result.toString();
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String input = sc.next();
String output = replaceNumbersWithText(input);
System.out.println(output);
}
}
151.翻转字符串里的单词
题目链接/文章讲解/视频讲解
class Solution {
public String reverseWords(String s) {
StringBuilder sb = removeSpace(s);
reverseString(sb, 0, sb.length() - 1);
reverseEachWord(sb);
return sb.toString();
}
private StringBuilder removeSpace(String s) {
int start = 0;
int end = s.length() - 1;
while (s.charAt(start) == ' ') start++;
while (s.charAt(end) == ' ') end--;
StringBuilder sb = new StringBuilder();
while (start <= end) {
char c = s.charAt(start);
if (c != ' ' || sb.charAt(sb.length() - 1) != ' ') {
sb.append(c);
}
start++;
}
return sb;
}
public void reverseString(StringBuilder sb, int start, int end) {
while (start < end) {
char temp = sb.charAt(start);
sb.setCharAt(start, sb.charAt(end));
sb.setCharAt(end, temp);
start++;
end--;
}
}
private void reverseEachWord(StringBuilder sb) {
int start = 0;
int end = 1;
int n = sb.length();
while (start < n) {
while (end < n && sb.charAt(end) != ' ') {
end++;
}
reverseString(sb, start, end - 1);
start = end + 1;
end = start + 1;
}
}
}
卡码网:55.右旋转字符串
题目链接/文章讲解/视频讲解
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
String s = scanner.next();
int len = s.length();
StringBuilder reversed = new StringBuilder(s).reverse();
StringBuilder reversedFirstSegment = new StringBuilder(reversed.substring(0, n)).reverse();
StringBuilder reversedSecondSegment = new StringBuilder(reversed.substring(n)).reverse();
String result = reversedFirstSegment.toString() + reversedSecondSegment.toString();
System.out.println(result);
}
}