Given a string, you need to reverse the order of characters in each word within a sentence while still preserving whitespace and initial word order.
Example 1:
Input: “Let’s take LeetCode contest”
Output: “s’teL ekat edoCteeL tsetnoc”
Note: In the string, each word is separated by single space and there will not be any extra space in the string.
题意:
给一个字符串,将每个单词倒叙,输出
思路:
用split()方法将给定字符串分隔成多个子字符串,遍历所有子字符串,append每个子字符串都用reverse()方法反转并append空格,使用trim()方法删除头尾空白符,用toString()方法返回String对象。
知识点:
String、StringBuilder、StringBuffer区别
- String 类:类不可改变,对象一旦创建,值不可改变
- StringBuilder:可改变,不产生新的未使用变量,多数情况下使用,速度快,线程不安全
- StringBuffer:可改变,不产生新的未使用变量,要求线程安全情况下使用,速度慢
方法
1、split()
:根据匹配给定的正则表达式来拆分字符串。
2、reverse()
:将字符串反转
3、trim()
: 方法用于删除字符串的头尾空白符。
4、toString()
:返回此对象本身(它已经是一个字符串)
class Solution {
public String reverseWords(String s) {
String[] words = s.split(" ");
StringBuilder res = new StringBuilder();
for(String word : words){
res.append(new StringBuilder(word).reverse().append(" "));//注意每个word都new
}
return res.toString().trim();
}
}