给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用1个空格分开,输入保证句子末尾没有多余的空格。
输出格式:每个测试用例的输出占一行,输出倒序后的句子。
输入样例:Hello World Here I Come
输出样例:
Come I Here World Hello
这道题目在之前好似已经做过,但是最近pta训练中,又有点找不到头脑。
下面是自己写的一段,c与c++都差不多了,这个写的有点糟糕
#include<iostream>
#include<stdio.h>
#include <string.h>
using namespace std;
int main (){
char s[88];
int i,j,n;
gets(s);
for(i=strlen(s)-1;i>0;i--)
if(s[i]==' '){
printf("%s ",&s[i+1]);
s[i]='\0';
}
printf("%s",s);
return 0;
}
这个参考在网上的一个大神写的,比较清晰
#include <stdio.h>
#include <string.h>
char str[81];
int main()
{
int i, k;
char *p;
gets(str);
k = strlen(str);
p = str + k;
while (1)
{
if ( p == str )
{
printf("%s\n", p);
break;
}
if (*p == ' ' && *(p+1) != ' ')
{
*p = '\0';
printf("%s ",p+1);
}
p--;
}
return 0;
}