统计一行文本的单词个数
本文是汇总了几个我认为比较好的方法,并进行了优化,仅供学习参考。
本题目要求编写程序统计一行字符中单词的个数。所谓“单词”是指连续不含空格的字符串,各单词之间用空格分隔,空格数可以是多个。
输入格式:
输入给出一行字符。
输出格式:
在一行中输出单词个数。
输入样例:
Let's go to room 209.
输出样例:
5
思路一:利用scanf的特性(使用%s转换说明,scanf会读取除空白以外的所有字符),可以很简单的完成这题。注意两个问题,一是代码虽然能通过PTA的编译器,但是在实际操作时需要输入EOF才能结束循环得到结果。然而Mac端的EOF操作为command+D,在dubug的时候用才能得到结果,在run时直接用会直接结束程序。二是采用了定长数组,可能空间不足或者浪费。
#include <stdio.h>
int main() {
char ch[100];
int i = 0;
while (scanf("%s", ch) == 1) {
i++;
}
printf("%d", i);
return 0;
}
思路二:利用题目中“单词”的定义。除了最后一个单词以外,其他单词一定结尾有空格,所以利用一个标志来代表单词,若遇到空格则单词数加一。到最后一个单词,结尾可能有空格也可能没有,但是一定有标志。
#include <stdio.h>
int main() {
int count = 0, flag = 0;
char str;
str = getchar();
while (str != '\n') {
if (str != ' ') //若非空格,标志为1表示单词
flag = 1;
if (flag == 1 && str == ' ')
//若是空格且标志为1,表示1个单词的末尾,标志重置为0
//若是空格且标志为0,表示出现连续空格
{
count++;
flag = 0;
}
str = getchar();
}
//判断最后一个单词
//此时若有单词则标志一定为1,若无单词,标志停留在0
if (flag == 1) { count++; }
printf("%d", count);
return 0;
}
参考:
1.link.
2.link