描述
对字符串中的所有单词进行倒排。
说明:
1、构成单词的字符只有26个大写或小写英文字母;
2、非构成单词的字符均视为单词间隔符;
3、要求倒排后的单词间隔符以一个空格表示;如果原字符串中相邻单词间有多个间隔符时,倒排转换后也只允许出现一个空格间隔符;
4、每个单词最长20个字母;
输入描述:
输入一行以空格来分隔的句子
输出描述:
输出句子的逆序
示例1
输入:
I am a student
复制
输出:
student a am I
复制
示例2
输入:
$bo*y gi!r#l
复制
输出:
l r gi y bo
#include <stdio.h>
#include <string.h>
int main(void)
{
char word[100][21] = {0};
char p;
int i=0, j=0;
int flag = 1;;
while(scanf("%c", &p) != EOF)
{
if((p>='a'&&p<='z') || (p>='A'&&p<='Z'))
{
word[i][j] = p;
j++;
flag = 1;
}
else
{
// 这个flag用来反映上一个是否是单词字符
// 若也不是单词字符,则此处无动作
if(flag)
{
if(i || j)
{
i++;
j = 0;
}
}
flag = 0;
}
}
for(j=i-1; j>=0; j--)
{
printf("%s ", word[j]);
}
printf("\n");
return 0;
}