题目描述:
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入描述:
测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。
字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)
组成的字符串,单词之间用1个空格分开,输入保证句子末尾没有多余的空
格。
输出描述:
每个测试用例的输出占一行,输出倒序后的句子。
测试用例:
输入:Hello World Here I Come
输出:Come I Here World Hello
思路:
- 首先将输入的字符串以空格分隔,放入一个字符串数组;
-利用栈先进后出的特性,将字符串数组中的字符串放入栈;
- 按照出栈的顺序打印即可
代码如下:
import java.util.Scanner;
import java.util.Stack;
public class Main {
private static void reverse(String str){
String[] strings = str.split(" ");
int n = strings.length;
Stack<String> stack = new Stack<>();
for (int i = 0; i < n; i++) {
stack.push(strings[i]);
}
while(!stack.isEmpty()){
System.out.printf(stack.pop()+" ");
}
}
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while(scanner.hasNext()){
String str = scanner.nextLine();
reverse(str);
}
}
}