判断字符串中单词个数(C++实现)

一.问题描述

在遇到一个英文句子时需要判断其中的单词个数,我们可能首先会想到的是将字符串录入数组后对其每一个元素进行遍历,如果出现空格元素,则对标记变量进行自加操作。例如:"I love c programmer"这句话中有两个空格,则对应的单词个数为3=(2+1)个,但是当每个单词之间以任意个空格隔开的时候,那么这种方法便不起作用了。

事实上,我们这个问题可以这样去思考:

1.从字符串第一个元素开始遍历,当碰到第一个元素不为空时,则判定为这是一个单词

2.对该单词进行快速跳过,直到在新的空格后遇到第一个非空元素,此时为另一个单词

3.重复上述操作,直到把所有字母浏览完

二.代码实现

*我们考虑到不仅会有空格作为单词间的区分,还会有其他字符作为区分

#include <iostream>
using namespace std;
int main()
{
    char str[100];
    int count=0;//单词个数标记量
    cout<<"please input the string"<<endl;
    gets(str);
    for (int i=0;i<strlen(str);i++)
    {
        if((str[i]>=65&&str[i]<=90)||(str[i]>=97&&str[i]<=122))//当判断第i个元素为大写字母或小写字母时count自加
        {
            count++;
            while(((str[i]>=65&&str[i]<=90)||(str[i]>=97&&str[i]<=122))&&str[i]!='\0')//当不是非字母元素时i自加(即将该单词快速遍历)
            {
                i++;
            }
        }
    }
    cout<<"count="<<count<<endl;
    return 0;

}

三.运行结果


猜你喜欢

转载自blog.csdn.net/f_IT_boy/article/details/80698430