PAT1009 BASIC:说反话 (20)

| 分类 算法  | 标签 pat 

问题描述

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

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

输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello

code

#include<stdio.h>
int main()
{
	char str[81]={0};
	int a[81]={0};
	gets(str);
	int i=0,j=0,m;
	for(;str[i]!='\0';i++)
	{
		if(str[i]==' ') a[j++]=i;
	}
	for(i=--j;i>=0;i--)
	{
		for(m=a[i]+1;str[m]!=' '&&str[m]!='\0';m++)
			printf("%c",str[m]);
		printf(" ");
	}
	for(i=0;str[i]!=' ';i++)
		printf("%c",str[i]);	
	return 0;	
}

//注意点
gets() reads a line from stdin into the buffer pointed to  by  s  until either a terminating newline or EOF, which it replaces with a null byte ('\0').  No check for buffer overrun is performed .

上一篇     下一篇