写程序统计一行字符中单词的个数。所谓“单词”是指连续不含空格的字符串,各单词之间用空格分隔,空格数可以是多个。
算法思路:word记录前一个字符是否为空格,当前字符不是空格且前一个字符是空格时,单词数+1。
#include<stdio.h>
#include<iostream>
#include<string>
#include<conio.h>
using namespace std;
//scanf() 读取字符串时以空格为分隔,遇到空格就认为当前字符串结束了,所以无法读取含有空格的字符串。
//gets() 认为空格也是字符串的一部分,只有遇到回车键时才认为字符串输入结束,所以,不管输入了多少个空格,只要不按下回车键,对 gets() 来说就是一个完整的字符串。
//gets(s); c=getchar();
int main(){
char c[100];
gets(c);
int num = 0, word = 0;
for(int i = 0; c[i] != '\0'; i++){
if(c[i] == ' ') //当前字符是空格
word = 0;
else if(word == 0){ //前一个字符是空格且当前字符不是空格
num++;
word = 1;
}
}
cout << num << endl;
return 0 ;
}
运行结果: