题目内容:
你的程序要读入一行文本,其中以空格分隔为若干个单词,以‘.’结束。你要输出这行文本中每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如“it's”算一个单词,长度为4。注意,行中可能出现连续的空格。
输入格式:
输入在一行中给出一行文本,以‘.’结束,结尾的句号不能计算在最后一个单词的长度内。
输出格式:
在一行中输出这行文本对应的单词的长度,每个长度之间以空格隔开,行末没有最后的空格。
输入样例:
It's great to see you here.
输出样例:
4 5 2 3 3 4
时间限制:500ms内存限制:32000kb
思路分析:看到本题,我当时最直接的想法就是建立一个较大的数组char a[100],把一整行文本输进去保存在字符数组里;再定义一个计数器count用于保存单词的字符个数。然后遍历数组,每遇到字符时,count就+1,当遍历遇到‘空格’时,则代表一个单词结束于是输出count的值,然后把count置为0。再遍历下去,直至遇到‘.’标志结束。
好像挺有道理吧?NO,还是图样图森破了!这里有几个很关键的点我都没考虑完整。
1.“一整行文本输进去保存在字符数组里”。
如果是采用scanf("%s", a);的方式,则会出现一个很大的问题:scanf接收包含空格的字符串时,字符串会被截断。如输入:hi joe,则数组中保存的只有hi,所以无法进行后续字符的计数。
2.“然后遍历数组,每遇到字符时,count就+1,当遍历遇到‘空格’时,则代表一个单词结束于是输出count的值,然后把count置为0”
这里只考虑到了最常规的一种情况:I love you.(这种不以空格开头且单词之间只有一个空格的文本)。对于其他情况则没有考虑到,如:以一连串空格开头或全部为空格的情况等。
综上出现的问题,换个思路,如下-->
我们没有必要将整个字符串保存下来,而采用%c一个个地读入字符,一边读入字符一边处理。每次读入一个字符,先从第一个不是空格的字符开始读,如果不是空格,count就+1,如果是空格且count不为0,说明之前已读的是完整的单词,就输出并且count清零;如果是空格且长度为0就继续。
图例如下:
代码:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
char c;
int count = 0;//单词长度
do
{
scanf("%c",&c);
if (c != '.'&&c != ' ')
{
count++;
}
else if (c == ' '&&count != 0)
{
printf("%d ", count);
count = 0;
}
} while (c!= '.');
printf("%d", count);
return 0;
}