PTA说反话(C语言)
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
思路:## 标题我的方法是定义一个足够大的字符数组,用‘%[^\n]’格式字符接收输入的一行字符串,用strlen函数定位字符串尾端,从尾端起逐字符判断,若出现空格即识别了一个单词,则将此空格后的字符输出,循环进行比对及输出即可
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
int i,j,k,n,len;
char eng[90];
scanf("%[^\n]",eng);//接收输入字符串
n=strlen(eng)-1;//定位字符串尾端
while(n>=0)//对接收到的字符串循环识别单词,直到尾端n小于0为止
{
for(i=n;eng[i]!=' '&&i>=0;i--);//
for(j=i+1;j<=n;j++)//对一个单词逐个输出
{
printf("%c",eng[j]);
}
if(i>=0)
putchar(' ');
n=n-(n-i)-1;//n等于n-(字符数+1(这里的+1是加的空格,尾端要移到空格之前))
}
return 0;
}