pat乙级 1009 说反话

1009 说反话
分数 20
作者 CHEN, Yue
单位 浙江大学
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

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

输出格式:
每个测试用例的输出占一行,输出倒序后的句子。

输入样例:
Hello World Here I Come

输出样例:
Come I Here World Hello

解题思路:我刚第一眼看到这个题的时候,我自己把题想复杂了,以为是多个空格的情况,再仔细一读题人家说单词之间只有一个空格,无所谓,我写了个有多个空格版本的一样可以,兼容性更好,利用的函数就是sscanf,因为sscanf性质去除之前的(空格,)

c语音版本:

#include
#include
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)

你可能感兴趣的:(pat考试)