设为首页收藏本站

新微赢技术网

 找回密码
 注册
搜索
热搜: 回贴
查看: 1710|回复: 1
打印 上一主题 下一主题

关于STL容器删除元素的模板方法

[复制链接]
跳转到指定楼层
1#
发表于 2009-11-3 03:07:45 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
程序代码:

template<class T,class Function>
void EraseFromBy(T& from,Function by)
{
T::iterator iter = from.begin() , prev = iter;
while(iter!=from.end())
{
if(by(*iter))
{
t.erase(iter);
if(prev == iter)
iter = prev = from.begin();
else
{
iter = prev;
iter++;
}
}
else
{
prev = iter;
iter++;
}
}
}




程序代码:

使用方法:
bool ShouldBeDeal(int a) //该函数传递给EraseFromBy,用于做删除的判断选项
{
if(a%2==0)
return true;
return false;
}
void main( void )
{
set<int> s;
s.insert(1);
s.insert(2);
s.insert(3);
s.insert(4);
copy(s.begin(),s.end(),ostream_iterator<int>(cout,"\n"));
EraseFromBy(s,ShouldBeDeal);
copy(s.begin(),s.end(),ostream_iterator<int>(cout,"\n"));
}
2#
发表于 2009-11-3 03:07:47 | 只看该作者
什么问题啊?大哥?编译不出来吗?
typename T::iterator iter = from.begin() , prev = iter;


t.erase(iter); //t是from把?

然后就是别加错了头文件

这个模版参数依赖太强了,不好,这个功能有现成的吧,stl里!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

申请友链|小黑屋|最新主题|手机版|新微赢技术网 ( 苏ICP备08020429号 )  

GMT+8, 2024-11-18 05:38 , Processed in 0.103790 second(s), 8 queries , Gzip On, Memcache On.

Powered by xuexi

© 2001-2013 HaiAn.Com.Cn Inc. 寰耽

快速回复 返回顶部 返回列表