一些我希望有帮助的观察结果(但要小心:以下代码未经测试)。
如果您Passenger
需要名字、姓氏和目的地,我想有一个Passenger
带有三个字符串参数的构造函数。
我想你Read_from_file()
应该变成类似的东西
void read_from_file(list<Passenger> & flist, string const & filename)
{
string firstN, lastN, dest;
ifstream input(filename.c_str());
while (input >> firstN >> lastN >> dest)
{
flist.push_back(Passenger(firstN, lastN, dest)); // for C++98
// flist.emplace_back(fistN, lastN, dest); // for C++11/14
}
// input.close(); no need for close: file closed by destructor
}
建议:通过引用传递参数,并const
尽可能使用 。
类似地,insert()
可以通过简单的方式进行调整(在两种不同的模式下,取决于您使用的是最近的 C++ 编译器还是 C++11 之前的编译器)
void insert(list<Passenger> & flist, string const & firstN,
string const & lastN, string const & dest)
{
flist.push_back(Passenger(firsN, lastN, dest)); // C++98 version
// flist.emplace_back(firsN, lastN, dest); // C++11/14 version
}
不太明显如何check_reservation()
。并且真正依赖于 C++98/C++11 问题。
我想你想要一个check_reservation()
想要找到一个Passenger
名字、姓氏和目的地的人。
在 C++11 中相当容易(假设您Passenger
包含 a firsN
、 alastN
和 adest
成员)
bool check_reservation(list<Passenger> const & flist, string const & firstN,
string const & lastN, string const & dest)
{
return flist.cend() != find_if(flist.cbegin(), flist.cend(),
[&](Passenger const & p)
(return (fistN == p.fistN)
&& (lastN == p.lastN)
&& (dest == p.dest);));
}
在 C++98 中,你没有 lambda 函数,所以比较棘手。您必须构造一个函子进行比较;就像是
struct person_eq : std::unary_function <Passenger, bool>
{
string const & f;
string const & l;
string const & d;
person_eq (string const & f0, string const & l0, string const & d0)
: f(f0), l(l0), d(d0)
{}
bool operator() (Passenger const & p) const
{ return (p.firstN == f) && (p.lastN == l) && (p.dest == d); }
};
你check_reservation()
应该变成类似的东西
bool check_reservation(list<Passenger> const & flist, string const & firstN,
string const & lastN, string const & dest)
{
return flist.cend() != find_if(flist.cbegin(), flist.cend(),
person_eq(fistN, lastN, dest));
}
我再说一遍:这段代码未经测试,所以要小心。
ps:对不起我的英语不好。
编辑
对不起:如果它是operator==
为你定义的Passenger
,你check_reservation()
可以很容易
bool check_reservation(list<Passenger> const & flist, string const & firstN,
string const & lastN, string const & dest)
{
return flist.cend() != find(flist.cbegin(), flist.cend(),
Passenger(firstN, lastN, dest));
}