思路: 这道题,其实有更简单的方法。但是呢,为了适合类似的、比这道题 要求更多难度更大 的一类题目,因此我使用了以下的方法。

所谓的要求更多的、难度更大,有以下几种:

  1. 所有单词之间不再是只有一个空格隔开,有可能有多个。这个时候,如果一再使用 .split(" ") 直接分割,会出问题的。因此,需要我们自行的判断字符串中,哪一段是空格,哪一段是单词
  2. 不再是句子逆序,而是 单个单词逆序。也就是说,如果输入数据是 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);
    }
}