c++ 统计一行文本中单词个数

在这里插入图片描述这个题直接统计空格数+1 是错的。只能实打实的找字母。

#include<iostream>
#include<cstring>
#include<algorithm>

using namespace std;
static void f(string s){
	int p1=0;//一个辅助下标
	int count = 0;//统计单词数量
	string ss[1000];//定义一个字符串数组存放单词
	int len = s.length();
	for(int i=0;i<len;i++){
		if((s[i]>='a'&&s[i]<='z')||(s[i]>='A'&&s[i]<='Z')||(s[i]>='0'&&s[i]<='9')){//当遇到合法字符时
			p1=i+1;		//p1指向下一个字符
			while(s[p1]!=' '&&p1<len){	//如果s[p1]为空格,说明从i到p1(不包括p1)之间的所有字符都是合法字符。当p1等于字符串长度时,p1指向字符串的最后一个元素的下一个位置
				p1++;	//当s[p1]不是空格且p1小于字符串长度时,p1一直指向合法字符,并不断向右扩展
			}
			ss[count++] = s.substr(i,p1-i);		//截取单词
				i=p1;	//i指向空格,待会儿for循环i++后 i可能指向新的合法字符
		}
	}
	cout<<count;
//	for(int i=0;i<count;i++){
//		cout<<ss[i];
//		if(i!=count-1) cout<<' ';
//	}	//输出单词 
}	
int main(){
	string s ;
	getline(cin,s);
	f(s);
	return 0;
}
发布了7 篇原创文章 · 获赞 15 · 访问量 802

猜你喜欢

转载自blog.csdn.net/weixin_42474371/article/details/97961728