- 时间限制:1秒空间限制:32768K
- 算法知识视频讲解
题目描述
对字符串中的所有单词进行倒排。
说明:
1、每个单词是以26个大写或小写英文字母构成;
2、非构成单词的字符均视为单词间隔符;
3、要求倒排后的单词间隔符以一个空格表示;如果原字符串中相邻单词间有多个间隔符时,倒排转换后也只允许出现一个空格间隔符;
4、每个单词最长20个字母;
输入描述:
输入一行以空格来分隔的句子
输出描述:
输出句子的逆序
输入例子:
I am a student
输出例子:
student a am I
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNext()) {
String s = sc.nextLine();
String[]ans = s.split("[^a-zA-Z]+");
for(int i=ans.length-1 ;i>1 ;i--){
System.out.print(ans[i]+" ");
}
//如果ans[0]是空字符串 那么ans[1]输出带空格就会使得字符串尾多一个空格
if(ans[0].length()==0){
System.out.println(ans[1]);
}else{
System.out.println(ans[1]+" "+ans[0]);
}
}
}
}