给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。
示例 1:
输入: "Let's take LeetCode contest"
输出: "s'teL ekat edoCteeL tsetnoc"
注意:在字符串中,每个单词由单个空格分隔,并且字符串中不会有任何额外的空格。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/reverse-words-in-a-string-iii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
思路:将字符串按照空格分成字符串数组,再把每一个字符串倒置,再添加空格连起来输出。
class Solution {
public String reverseWords(String s) {
String[] words = s.split(" ");
StringBuilder builder = new StringBuilder();
for(String word : words) {
builder.append(new StringBuilder(word).reverse() + " ");
}
System.out.println(builder.toString().trim());
return builder.toString().trim();
}
}
一、知识点
1. split的用法
将一个字符串分割为子字符串,然后将结果作为字符串数组返回。
2. reverse的用法
StringBuffer的类才有这个方法,reverse()方法表示的是将一个输入流倒叙输出。
3. trim的用法
去掉首尾字符串的空格。
二、心得体会
1. 熟悉StringBuilder类可定义一个可变的字符串,它可用的方法有append(String str)和reverse()方法。
2. for each语句格式:for(String word : words)