人生苦短,我用python
class Solution:
def reverseWords(self, s: str) -> str:
return " ".join(s.split()[::-1])
但是这样的方式太取巧了,对语言要求也高,所以就不用这种方法了。
用Java的话就很多细节需要考虑,首先就需要用trim
去除空格,然后再遍历的时候,如果碰到了连续的空格,也需要只计算一个空格。
class Solution {
public String reverseWords(String s) {
if(null == s || s.isBlank()) {
return s.trim();
}
List<String> words = new ArrayList<>();
StringBuilder sb = new StringBuilder();
for(var c : s.trim().toCharArray()) {
if(c == ' ') {
if(sb.length() > 0) {
words.add(sb.toString());
sb.setLength(0);
} else {
continue;
}
} else {
sb.append(c);
}
}
words.add(sb.toString());
String[] strs = new String[words.size()];
for(int i = 0; i < words.size(); i++) {
strs[i] = words.get(words.size() - 1 - i);
}
return String.join(" ", strs).trim();
}
}