题目描述
已知一个总长度不超过10000的字符串,字符串中只包含大写字母“A—Z”、小写字母“a—z”和空格‘ ’。空格用于分割单词,空格的个数不超过1000个。你的任务是将字符串中用空格分隔的单词打印出来。
你要按照如下要求完成任务:
1.利用指针数组指向每个单词的开始位置。
2.把字符串中单词结束后的空格改为“\0”,然后使用指针数组将每个单词打印出来。
3.不可直接输出或使用二维数组输出单词。
输入与输出要求:输入一个字符串,满足题目描述,占一行。输出这个字符串中的单词,每个单词占一行。
程序运行效果:
Sample 1:
You are great↙
You↙
are↙
great↙
Sample 2:
itisalongword↙
itisalongword↙
程序代码:
#include<stdio.h>
#include<string.h>
int main(void)
{
char a[10050];
char *p = a;
char *str[1001];//关键:根据题意,可能会有1001个单词的数据,所以定义指针数组(1001)!!!
int i = 0, j = 0;
fgets(a, 10050, stdin);//读取字符串(含'\n')
int l = strlen(a);//读取字符串长度
while (i <= l - 1)
{
if (a[i] != ' ')//判断第一个字符是否为空格,若不是,则存入指针数组,继续进行
{
str[j] = &a[i];
j++;
while (a[i] != ' '&&a[i]!='\n')//继续运行,直到字符为空格或换行符为止
{
i++;
}
if (a[i] == ' '||a[i]=='\n')//将空格或换行符改为终止符
a[i] = '\0';
}
else if (a[i] == ' ')
a[i] = '\0';
i++;
}
j = j - 1;
for (i = 0; i <= j; i++)
{
printf("%s\n", str[i]);
}
return 0;
}
关键:题目中描述:空格的个数不超过1000个。这个信息提示我们至多会有1001个单词,为一个考点(避免数组越界)