5-52 单词长度   (15分)

本文介绍了一个使用C++编写的程序,该程序能够读取一行包含多个单词的文本,并输出每个单词的长度。程序考虑了多种特殊情况,如开头空格、结尾句点及连续空格等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

你的程序要读入一行文本,其中以空格分隔为若干个单词,以.结束。你要输出每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如it's算一个单词,长度为4。注意,行中可能出现连续的空格;最后的.不计算在内。

输入格式:

输入在一行中给出一行文本,以.结束

提示:scanf("%c",...);来读入一个字符,直到读到.为止。

输出格式:

在一行中输出这行文本对应的单词的长度,每个长度之间以空格隔开,行末没有最后的空格。

输入样例:

It's great to see you here.

输出样例:

4 5 2 3 3 4


解析:

注意空格的情况

1、开头有空格

2、点前面有空格

3、有多个连续空格

#include <iostream>
#include <string>
#include <queue>
using namespace std;
int main () {
	int len, i = -1, cnt = 0, flag = 0;
	queue<int> q;
	string s;
	getline(cin, s); //接收整句话 
	len = s.length();
	while ( ++i < len ) {
		if( s[i] != '.' ) {
			if ( s[i] != ' ') { //不是空格和点就计数 
				cnt++;
				flag = 0;	//表示遇到不是空格 
			}
			else if ( !flag && cnt != 0 ) { //如果遇到第一个空格,且这个空格不是开头的 
				//cout << cnt;
				q.push(cnt);
				cnt = 0;	//输出后置0 
				flag = 1;	//表示遇到空格,用来处理多个连续空格 
			}
		}
		else if ( cnt != 0 ) //如果点前面没有空格 
			//cout << " " << cnt;
			q.push(cnt);
	}
	if ( q.empty() ) { }	//为空时什么也不做 
	else {
		cout << q.front();
		q.pop();
		while ( !q.empty() ) {
			cout << " " << q.front();
			q.pop();
		}
	}
	return 0;
}





实验3-统计某电商网站买家收藏商品数量 现有某电商网站用户对商品的收藏数据,记录了用户收藏的商品id以及收藏日期,名为buyer_favorite1。buyer_favorite1包含:买家id,商品id,收藏日期这三个字段,数据以“\t”割,样本数据及格式如下: 1.买家id   商品id    收藏日期   2.10181   1000481   2010-04-04 16:54:31   3.20001   1001597   2010-04-07 15:07:52   4.20001   1001560   2010-04-07 15:08:27   5.20042   1001368   2010-04-08 08:20:30   6.20067   1002061   2010-04-08 16:45:33   7.20056   1003289   2010-04-12 10:50:55   8.20056   1003290   2010-04-12 11:57:35   9.20056   1003292   2010-04-12 12:05:29   10.20054   1002420   2010-04-14 15:24:12   11.20055   1001679   2010-04-14 19:46:04   12.20054   1010675   2010-04-14 15:23:53   13.20054   1002429   2010-04-14 17:52:45   14.20076   1002427   2010-04-14 19:35:39   15.20054   1003326   2010-04-20 12:54:44   16.20056   1002420   2010-04-15 11:24:49   17.20064   1002422   2010-04-15 11:35:54   18.20056   1003066   2010-04-15 11:43:01   19.20056   1003055   2010-04-15 11:43:06   20.20056   1010183   2010-04-15 11:45:24   21.20056   1002422   2010-04-15 11:45:49   22.20056   1003100   2010-04-15 11:45:54   23.20056   1003094   2010-04-15 11:45:57   24.20056   1003064   2010-04-15 11:46:04   25.20056   1010178   2010-04-15 16:15:20   26.20076   1003101   2010-04-15 16:37:27   27.20076   1003103   2010-04-15 16:37:05   28.20076   1003100   2010-04-15 16:37:18   29.20076   1003066   2010-04-15 16:37:31   30.20054   1003103   2010-04-15 16:40:14   31.20054   1003100   2010-04-15 16:40:16   要求编写MapReduce程序,统计每个买家收藏商品数量,并撰写实验报告。
最新发布
03-28
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值