您的位置:首页 > 编程语言 > Java开发

Java - PAT - 1009. 说反话 (20)

2016-06-18 22:26 585 查看
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用1个空格分开,输入保证句子末尾没有多余的空格。

输出格式:每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come

输出样例:
Come I Here World Hello

/*
* 思路:
* 1.读取一行字符串
* 2.以一个或者多个空格拆分为字符串数组
* 3.逆序输出数组元素
*/
import java.util.Scanner;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
String[]words = s.split("\\s+");
for(int i=words.length-1 ;i>0 ;i--){
System.out.print(words[i]+" ");
}
System.out.println(words[0]);
}
}


附上C++代码对比学习

#include<cstdio>
#include<string>

using namespace std;

int main(){
char str[90][90];
int num = 0;
while(scanf("%s",str[num])!=EOF){
num ++;
}
for(int i=num-1; i>=0 ;i--){
if(i!=num-1){
printf(" %s",str[i]);
}
else{
printf("%s",str[i]);
}
}
printf("\n");
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: