思路
判断某一个位置前面不是字母,而此位置是字母,每当出现此位置,那么count就自增。当然,对于输入行的开头,若没有空格或者其他字符,而是直接一个单词或字符,这种情况代码中第一个if就以考虑。如此一来,无论是含有多个空格还是标点符号,亦或是单词与特殊字符夹杂,都无所畏惧了。
#include<iostream>
#include<string>
#include<cctype>
using namespace std;
int main()
{ /*统计单词个数*/
string t;
getline(cin, t);
int count = 0;
char* p = &t[0];
char* q = p + t.size();
if (isupper(*p) || islower(*p)) ++count;
while (p < q)
{
++p;
if (
isupper(*p) || islower(*p) && !(isupper(*(p - 1)) || islower(*(p - 1)))
) ++count;
}
cout << count << endl;
}
代码解释
这里用isupper()和islower()判断该位置是不是字母,用q指向string对象末尾位置,进行判断即可,具体同思路
当然可以也用c语言描述,头文件改成ctype.h输入部分用gets函数或者while加getchar,然后用一个数组接收,注意数组要开的大一点,防止越界风险。然后q指针用p+数组长度赋值。最后用printf输出count的值即可。