程序设计入门C语言 --- 单词长度

题目内容:

你的程序要读入一行文本,其中以空格分隔为若干个单词,以‘.’结束。你要输出这行文本中每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如“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;
}

 

 

猜你喜欢

转载自blog.csdn.net/melody_1016/article/details/81364765