这道题目出自谭浩强的C语言程序设计 P165 的例6.8
个人觉得这道题目看似简单,但是其中原理理解消化得需要点时间,因为本章的字符数组相对于前边的章节,又上升了一个难度。
先来看思路:
这道题的Key point就是怎样确定“出现了新的单词"
可以先对字符进行逐字检查,如果出现地新单词,设立一个变量num=0,让其+1,进行统计。
而如何统计出现新单词,想像一下,输入一个i am a boy,其中能够证明新的单词是不是只有空格?所以将空格设立为判定新单词的标准,并且定义两个新变量字符变量c,word,如果出现了空格(也就是c==0),并将word=0。但如果word=0,c!=0,也就是上一个字符为0,下一个字符不等于0,表示出现了新单词,这时候就可以将num+1了,并且也让word=1;
word=0,代表前一个字符是空格;
word!=0,代表前一个字符为非空格。
#include<stdio.h>
int main()
{
char string[81];
int i,num=0,word=0;
char c;
gets(string);
for(i=0;((c=string[i])!='\0');i++)
if(c==' ') word=0;
else if(word==0)
{
word=1;
num++;
}
printf("there are %d words in this line.\n",num);
return 0;
}