1009 说反话
分数 20
作者 CHEN, Yue
单位 浙江大学
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
解题思路:我刚第一眼看到这个题的时候,我自己把题想复杂了,以为是多个空格的情况,再仔细一读题人家说单词之间只有一个空格,无所谓,我写了个有多个空格版本的一样可以,兼容性更好,利用的函数就是sscanf,因为sscanf性质去除之前的(空格,)
c语音版本:
#include<stdio.h>
#include<string.h>
int main()
{
char a[100];
char b[100][100];
gets(a);
int count=0,count_b=0;
int len,t=0,i,flag=0;
int space[100]={0}; //这个是计算空格的 方便sscanf下次取址
for(i=0;i<strlen(a);i++)
{
if(a[i]==' ')
space[count]++,flag=1; //flag是标记之前是否是空格
else if(a[i]!=' '&&flag==1)
count++,flag=0;
}
count=0;
while(sscanf(a+t,"%s",b[count_b])!=EOF)
{
t+=space[count]+strlen(b[count_b]);
count++;
count_b++;
}
for(i=count_b-1;i>0;i--)
{
printf("%s ",b[i]);
}
printf("%s\n",b[i]);
return 0;
}
python版本:用python写非常容易因为python有split方法 极其简单
s=input().split()
s.reverse()
s=' '.join(s)
print(s)