输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。句子中两个单词之间由一个空格符隔开。
输入:多组输入输出。
每一行需要改变的句子。(句中只包含大小写英文字母及空格)
输出:与输入相对应输出改变后的句子。
输入样例:
who are you
Welcome to Northeast university of Qinhuangdao
输出样例:
you are who
Qinhuangdao of university Northeast to Welcome

基本思路:
这里自然想到要将英语句子中的英文字母存入数组当中
并且为多行输入则自然或考虑到有三层循环,所以会有 结构体来存储。

#include<stdio.h>
#include<string.h>
#define N 100
typedef struct List        //结构体来记录英文句子中的单词以及单词的个数 
{
   
	char word[N][N];
	int num;
}Word;

int main()
{
   
	char a[N][N];
	Word c[N];
	int i,j,k,count=0;
	
	while(gets(a[count]))
	{
   
		for(i=0,j=0,k=0;a[count][i]!='\0';i++)
		{
   
			if(a[count][i]!=' ')
			c[count].word[j][k++]=a[count][i];      //以空格判断是否为单词,并且用空格作为间断来用结构体存储句子中的单词 
			else {
   
				c[count].word[j][k]='\0';          //若读到空格字符,那么将该空格字符重新赋为\0,并换行存下一个英文单词 
				k=0;
				j++;
			}
		}
		c[count].num=j;                     //结构体存入句子中的单词个数 
		count++;
	}
	
	for(i=0;i<count;i++)
    {
   
    	for(j=c[i].num;j>=0;j--)
    	printf("%s ",c[i].word[j]);
    	printf("\n");
	}
	
	return 0;
}