思路: 这道题,其实有更简单的方法。但是呢,为了适合类似的、比这道题 要求更多、难度更大 的一类题目,因此我使用了以下的方法。
所谓的要求更多的、难度更大,有以下几种:
- 所有单词之间不再是只有一个空格隔开,有可能有多个。这个时候,如果一再使用 .split(" ") 直接分割,会出问题的。因此,需要我们自行的判断字符串中,哪一段是空格,哪一段是单词。
- 不再是句子逆序,而是 单个单词逆序。也就是说,如果输入数据是 I am a boy,那么最终的输出结果应该是 I ma a yob。
综上所示,以下代码只是能够适应更多的题目,并不是本题的最优解法!
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
String str = scan.nextLine();
char[] chrs = str.toCharArray();
Stack<String> stack = new Stack<>();
StringBuffer sb = new StringBuffer("");
int sign = 0;
int start = 0;
for (int i = 0; i < chrs.length; i++) {
char currentChar = chrs[i];
if (currentChar == ' ') {
if (sign == 1) {
sign = 0;
stack.push(str.substring(start, i));
}
stack.push(" ");
} else {
if (sign == 0) {
sign = 1;
start = i;
}
}
}
if (sign == 1) {
stack.push(str.substring(start));
}
while (!stack.isEmpty()) {
sb.append(stack.pop());
}
System.out.println(sb);
}
}