#include <stdio.h>
#include <string.h>
int main(void)
{
char s[80] = {'\0'};
char Words[15][20];
int i, j, len;
memset(Words, 0, sizeof(Words));
gets(s);
len = strlen(s);
int cnt = 0;
for(i = 0; i < len; i++)
{
// 这两个循环的嵌套、条件调试了很久才得到
for(j = 0; j < 20 && i < len; j++, i++)
{
if(s[i] == ' ')
{
Words[cnt][j + 1] = '\0';
cnt ++;
break;
}
Words[cnt][j] = s[i];
}
}
// 倒着输出单词
for(i = cnt; i >= 0; i--)
{
// puts(Words[i]);
for(j = 0; Words[i][j] != '\0'; j++)
putchar(Words[i][j]);
if(i > 0)
putchar(' ');
}
return 0;
}
/* 25min +
本题核心的算法是:
先根据空格划分成一个个的单词,把单词存在一个二维数组中,然后倒着输出单词
*/10-0. 说反话 (20)
最新推荐文章于 2020-08-14 11:02:18 发布
本文介绍了一种使用C语言实现的字符串逆序输出的方法。该方法首先将输入的字符串按空格划分为多个单词,并将这些单词存储在一个二维数组中。接着,程序通过倒序遍历这个数组来实现单词的逆序输出。
2818

被折叠的 条评论
为什么被折叠?



