给定输入字符串,逐个单词地反转字符串。
例如,给定s =“天空是蓝色”,则返回“蓝色是天空”。
Java解决方案
这个问题非常简单。我们首先将字符串拆分为单词数组,然后遍历该数组并将每个元素添加到新字符串中。注意:应该使用StringBuilder来避免创建太多的字符串。如果字符串很长,则使用String是不可扩展的,因为String是不可变的,将创建太多对象并进行垃圾回收。
class Solution {
public String reverseWords(String s) {
if (s == null || s.length() == 0) {
return "";
}
// split to words by space
String[] arr = s.split(" ");
StringBuilder sb = new StringBuilder();
for (int i = arr.length - 1; i >= 0; --i) {
if (!arr[i].equals("")) {
sb.append(arr[i]).append(" ");
}
}
return sb.length() == 0 ? "" : sb.substring(0, sb.length() - 1);
}}
最后,开发这么多年我也总结了一套学习Java的资料与面试题,如果你在技术上面想提升自己的话,可以关注我,私信发送领取资料或者在评论区留下自己的联系方式,有时间记得帮我点下转发让跟多的人看到哦。