本题要求实现一个程序,检查你朋友给你发来的信息里有没有 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来做判断是否查找成功