stl find_if在map中查找元素的应用

                                            stl   find_if在map中查找元素的应用
  find_if算法用来在map中查找value符合条件的pair元素,返回指向该符合条件元素的迭代器,如果找到,那么返回最后一个元素的后一个元素end();

1.首先要定义头文件
 #include <algorithm>

2.定义一个比较函数
bool  equal(pair<int,HTREEITEM> data, HTREEITEM target)
{
 if (data.second==target)
 {
  return   true;
 }
 else
 {
  return   false;
 }
}

map<int,HTREEITEM>  mymap;

3.使用
    m_TreeChannel  是一个CTreeCtrl 对象
    HTREEITEM  htreeItem=m_TreeChannel.GetSelectedItem();

 //查找是否存在符合条件的,如果是直接返回true,否则false
 map<int,HTREEITEM>::iterator   iter_find;
 iter_find=find_if(mymap.begin(),mymap.end(),bind2nd(ptr_fun(equal),htreeItem));
 if (iter_find!=mymap.end())
 {
  return true ;
 }
 else
 {
     return false ;
 }
 
 
如上,这样就不要通过for循环来查找map中是否有符合条件的value值存在了。 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值