[C++] vector删除指定元素

背景

最近在工作中遇到一个问题,问题可简化如下:

在推荐系统中,对某个user的召回候选item集合进行打分排序,item集合存放在一个召回列表vector中。需要实现的功能为,在召回item列表送入模型打分之前,先做过滤。即对于user已经拥有的item,不再将这些item送入模型进行打分。

例如:user1已经拥有item1,item2。则需要将召回列表vector中的item1,item2过滤掉。

解决方案

int32_t filter_number = 0;
std::set<int64_t> user_already_ow_item_set;
vector<ItemInfo>::iterator it;
for (it = item_recall_list.begin(); it != item_recall_list.end();) {
    if (user_already_own_item_set.find((*it).item_id) != user_already_own_item_set.end()) {
      it = item_recall_list.erase(it); // 不可写为item_recall_list.erase(it);
      filter_number++;
    } else {
      ++it;	// 
    }
}

知识点

C++ vector中,实际删除元素使用的是容器vecrot中std::vector::erase()方法;std::remove()并不删除元素,因为容器的size()没有变化,只是元素的替换。

  • std::vector::erase() 函数原型:
    iterator erase (iterator position);  //删除指定元素
    iterator erase (iterator first, iterator last);  //删除指定范围内的元素

    返回值:指向删除元素(或范围)的下一个元素。(An iterator pointing to the new location of the element that followed the last element erased by the function call. This is the container end if the operation erased the last element in the sequence.)

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值