题目链接🔗:
344.反转字符串
541. 反转字符串II
替换数字
151.翻转字符串里的单词
右旋字符串
反转字符串
左右字符交换,循环直到左指针下标大于右指针下标
反转字符串II
和第一题没有什么不同,可以用一个限制左右范围的函数,对一个字符串进行反复反转,至于最后一次判断剩余字符数量大于k,翻转k个字符,没有k个反转全部剩余字符。
替换数字
用 StringBuilder,append 每个字符串中的字符,检测如果是数字直接 append(“number”),最后全部 append 结束后,toStirng输出。
翻转字符串里的单词
正常的做法就是先全部反转,之后从每个单词开始到空格再翻转,但是用这种方法很优雅
class Solution {
public String reverseWords(String s) {
s = s.trim();
List<String> wordList = Arrays.asList(s.split("\\s+"));
Collections.reverse(wordList);
return String.join(" ", wordList);
}
}
右旋字符串
和上一题很相似,但是这次不是按照空格进行划分进行二次翻转,是按照给出的数字,也就是全部反转后,将字符串按照给出的数组分为两个范围,再次翻转一遍。
总结
这些字符串的题目还是印象很深,不是很难。