吃火锅(find函数的使用)

在这里插入图片描述
本题要求实现一个程序,检查你朋友给你发来的信息里有没有 chi1 huo3 guo1

输入格式:
输入每行给出一句不超过 80 个字符的、以回车结尾的朋友信息,信息为非空字符串,仅包括字母、数字、空格、可见的半角标点符号。当读到某一行只有一个英文句点 . 时,输入结束,此行不算信息。

输出格式:
首先输出朋友信息的总条数。
在第二行中首先输出第一次出现 chi1 huo3 guo1 的信息是第几条(从 1 开始计数),然后输出这类信息的总条数,其间以一个空格分隔。题目保证输出的所有数字不超过 100。

如果朋友从头到尾都没提 chi1 huo3 guo1这个关键词,则在第二行输出一个表情 -_-#。

输入样例 1:
Hello!
are you there?
wantta chi1 huo3 guo1?
that’s so li hai le
our story begins from chi1 huo3 guo1 le
.
输出样例 1:
5
3 2

输入样例 2:
Hello!
are you there?
wantta qi huo3 guo1 chi1huo3guo1?
that’s so li hai le
our story begins from ci1 huo4 guo2 le
.
输出样例 2:
5
-_-#

这个题可以用find函数完成
具体代码如下:

#include <iostream>
using namespace std;
int main() {
	string s;
	int num1 = 0, t, num2 = 0, flag = 0;  
	//num1朋友消息总条数,t记录第一条的序号,
	//num2含有吃火锅消息条数 ,flag标记是否是第一条 
	while(1){
		getline(cin, s);
		if(s == ".") break;
		num1++;
		if(s.find("chi1 huo3 guo1") != s.npos){
			num2++;
			if(!flag){
				t = num1;
				flag = 1;
			}
		}
	}
	if(num2) printf("%d\n%d %d", num1, t, num2);
	else printf("%d\n-_-#", num1);
}

关于find函数:
string自带的find(),可查找指定字符串和指定字符。
使用方法:如在string1中查找string2,string1.find(string2);返回值为string2第一次在string1中出现的位置。
若希望在特定位置开始查找,可使用 string1.find(string2,location);
如果找不到,则返回值为string::npos ,即对于string,通过a.find(val)==string::npos来做判断是否查找成功

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值