#include "stdafx.h"
#include<iostream>
#include<string>
#include<fstream>
#include<algorithm>
using namespace std;
int main()
{
string str;
string str1="25";
string str2 = "*";
ifstream ifs("aaa.txt");
int num1=0,num2=0;
for (; ifs.good();)
{
getline(ifs, str);
if(str.find(str1)!=string::npos)
{
num1=num1+1;
}
if(str.find(str2)!=string::npos && str.find(str1)!=string::npos)
{
num2 = num2+1;
}
}
cout<<num1-num2+num2*2;
ifs.close();
}
思路:读取文件,将每一行存入一个string中,再利用find函数查找,其中查找失败会返回string::npos,查找成功会返回所要查找字符串的下标位置(首字母),统计包含“25”的string的个数,再统计出,同时包含“25”和“*”的个数,即可得出天数。
最开始本来打算用向量来做,也是首先将文件按行读取,每一行存入到一个一维向量,再将这个一维向量放到二维向量中,最后利用find函数查找“25”和“*”。
然而,在实践过程中,发现find函数使用时,只能查找与所定义vector类型相同,也就是如果要查找“25”,那么必须定义位为vector <string> 类型。但是这样的话,每一行变成了一个一维向量的元素,例如。如果将第一行赋给向量s,那么s[0]是第一行,而不是所有的s是第一行。然而此时,find只能找s里的元素,而s的元素就是第一行,我们要找元素中一段字符串,不能实现。
如果定义为vector<char> s 的话,find又不能找字符串,只能找字符。
最后想来想去还是用string。