在元素为结构体的向量中查找

如下,
struct Club
{
 string m_str;
 int m_i;
 Club(const string &s, int i)
 {
  m_str = s;
  m_i = i;
 }
};
 
vector<Club> vClub;
Club a("randylin",2);
Club b("forrest",1);
vector<Club> vClub;
vClub.push_back(a);
vClub.push_back(b);
在vClub中精确查找
m_str == "randy",m_i == 2
或者查找
m_str == "randy",取m_i
 
有两种方法:
(1)find
(2)find_if
下面是示例代码
//find_if方法
//自定义函数对象(谓词)
class Club_eq
{
 public:
 Club_eq(const string& ss):s(ss){}
  bool operator() (const Club& c) const
 {
  return c.m_str == s;
 }

private:
 string s;
};
int main()
{
 Club a("randylin",2);
 Club b("forrest",1);
 vector<Club> vClub;
 vClub.push_back(a);
 vClub.push_back(b);
 vector<Club>::iterator iter;
 iter = find_if(vClub.begin(), vClub.end(), Club_eq("randylin"));
 if(iter != vClub.end())
 {
  cout << iter->m_i << endl;
 }
 return 1;
}
//find方法
//在结结构体重载operator==操作符
struct Club
{
 string m_str;
 int m_i;
 Club(const string &s, int i)
 {
  m_str = s;
  m_i = i;
 }
 bool operator==(const Club& c) const
 {
  return c.m_str == m_str && c.m_i == m_i;//这里可以自定匹配个数
 }

};
int main()
{
 Club a("randylin",2);
 Club b("forrest",1);
 vector<Club> vClub;
 vClub.push_back(a);
 vClub.push_back(b);
 vector<Club>::iterator iter;
 Club tmp("randylin",2); 
 iter = find(vClub.begin(), vClub.end(), tmp);
 if(iter != vClub.end())
 {
  cout << iter->m_i << endl;
 }
 return 1;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值