C++学习_STL算法

STL提供了许多算法,它们大多依赖于迭代器和仿函数,可以运行在几乎所有容器和数组上. 一些算法并不常用,名称有点混乱,而且很容易简单地实现, 不过了解一下常用的STL算法还是很有必要的.

一, for_each  这个算法还是比较常用的,

1,第三个参数op可以是函数或仿函数, 可以通过op改变遍历对象,(不能改变关联容器,因为它们的元素是const的)

2,op可以有返回值,但是会被废弃

3,for_each的返回值是op, 如果op是一个仿函数,可以利用这一特性记录op的变化


二, find, find_if

查找系列函数有很多,这两个应该是用的稍微多一点的:

InputIt find( InputIt first, InputIt last, const T& value );

InputIt find_if( InputIt first, InputIt last,  UnaryPredicate p );

返回迭代器


三, copy, transform

OutputIt copy( InputIt first, InputIt last, OutputIt d_first );

OutputIt transform( InputIt first1, InputIt last1, OutputIt d_first, UnaryOperation unary_op );

这两个算法有一个OutputIt 参数,注意如果是新增元素,要用back_inserter等迭代器,否则会在原位置替代

transform的OutputIt 如果与InputIt 取同一值,会得到与for_each一样的效果


四 排序算法sort和stable_sort

1,sort采用快排,stable_sort采用堆排,一般来说sort更快

2,调用的容器必须支持随机存储迭代器,因此list不能用,list有其自己的sort函数

3,STL还提供了几个局部排序算法partial_sort和nth_element,不过应用不多

4,STL提供了专门的堆算法,make_heap,push_heap,pop_heap,heap_sort. 不过如果只是要排序,应该直接调用stable_sort


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值