输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。句子中两个单词之间由一个空格符隔开。
输入:多组输入输出。
每一行需要改变的句子。(句中只包含大小写英文字母及空格)
输出:与输入相对应输出改变后的句子。
输入样例:
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;
}