加锁和解锁,也可以在构造函数和析构函数里面,自动调用。

相等和等价的关系:等价是用在排序的时候,跟less函数有关。

vector,deque,string 要用erase-remove组合;而关联容器,直接erase就可以了。

copy(x.begin(), x.end(), ostream_iterator<string>(cout, "\n"));

但是如果x的类型是string*,就不行。

自定义一个print(const string*ps);

然后 for_each(x.begin(), x.end(), print);

或者

struct Dereference{

template<typename T>

const T& operator()(const T* ptr)const {

return *ptr;

}

}

transform(x.begin(), x.end(),

ostream_iterator<string>(cout, "\n"),

Dereference());

注意transform的两种形式:

template < class InputIterator, class OutputIterator, class UnaryOperator >
OutputIterator transform ( InputIterator first1, InputIterator last1,
OutputIterator result, UnaryOperator op ); template < class InputIterator1, class InputIterator2,
class OutputIterator, class BinaryOperator >
OutputIterator transform ( InputIterator1 first1, InputIterator1 last1,
InputIterator2 first2, OutputIterator result,
BinaryOperator binary_op ); 有如下两个使用原型,一个将迭代器区间[first,last)中元素,执行一元函数对象op操作,交换后的结果放在[result,result+(last-first))区间中。另一个将迭代器区间[first1,last1)的元素*i,依次与[first2,first2+(last-first))的元素*j,执行二元函数操作binary_op(*i,*j),交换结果放在[result,result+(last1-first1))。

set的比较类型,是less_equal,注意语义里面带了equal。

可以我看cplusplus网站上面定义的是less。

那还是以less为准吧。

http://www.cplusplus.com/reference/set/set/set/

用advance和distance可以把const iterator 转换成 iterator

其实是这样,iterator i = x.begin(); ci是const iterator

那么 advance(i, distance(i, ci));也就是把 i 移动到 ci 的位置。

对于 reverse_iterator类型,有一个base函数,能够返回对应的正向iterator信息,因为有的函数只支持正向iterator.

但是这个base返回的iterator,只能在insert的时候用,因为指向的reverse那个方向的前一个节点。

对于erase的时候,就不能用了,因为和reverse的指的不是一个节点。

算法

transform 很多地方都能够用到。

但是一定要注意,result的空间要大于等于待放入的内容。不然结果未定义。

比如:

尾部加入,用back_inserter

result.reserve(result.size()+values.size());

transform(value.begin(), value.end(),

back_inserter(result),

transfunc);

如果需要覆盖

if (result.size() < value.size()) {

result.resize(value.size())

}

transform(value.begin(), value.end(),

result.begin(),

transfunc);

partial_sort对于头部排序,很好用。

partial_sort(w.begin(), w.begin()+20, w.end(), comp);

而如果前面20个也不关心顺序,那么用

nth_element

用法:

nth_element(w.begin(), w.begin()+19, w.end(), comp);

partial_sort是不稳定的,nth_element,sort也没有提供稳定性。

partition函数用来分隔的。注意,partition是快排很好的工具,但是stl里面的partition因为第三个参数是一个bool函数,所以在快排的时候,不太好用。

bool函数为true的,放在partition的前面。

bool isOdd(int i) {return (i%)==;}

int ir[] = {, , , , , };
vector<int> x(ir, ir+sizeof(ir)/sizeof(int)); vector<int>::iterator itr = partition(x.begin(), x.end(), isOdd); copy(x.begin(), itr, ostream_iterator<int>(cout, " "));
cout<<endl;
copy(itr, x.end(), ostream_iterator<int>(cout, " "));

输出:

   

stack和vector都有 emplace函数,而stack其实是调用了底层容器的emplace_back,

都是C++11的。

The container is extended by inserting a new element at position. This new element is constructed in place using args as the arguments for its construction.

int main ()
{
std::vector<int> myvector = {,,}; auto it = myvector.emplace ( myvector.begin()+, );
myvector.emplace ( it, );
myvector.emplace ( myvector.end(), ); std::cout << "myvector contains:";
for (auto& x: myvector)
std::cout << ' ' << x;
std::cout << '\n'; return ;
} Output:
myvector contains:

最新文章

  1. 【转】java调用webservice
  2. 取得ascii的例子
  3. Java基础之写文件——使用多个视图缓冲区(PrimesToFile2)
  4. 面向对象设计模式--观察者模式(Observer)
  5. Android编程: fragment组件、菜单和Intent组件
  6. WIN7建立wifi热点及无法启动承载网络的解决办法
  7. NOI2012 魔幻棋盘
  8. CImageList使用指南
  9. HNTX_PC 代码总结
  10. java:包、继承,访问修饰符
  11. 用git提交源代码
  12. 刘志梅 201771010115 《面向对象程序设计(java)》 第九周学习总结
  13. Django -- 部署Django 静态文件不能获取
  14. springboot搭建环境整合jsp页面整合mybatis
  15. Python pycharm 常用快捷键
  16. 腾讯旗下网站的很多URL都包含“cgi-bin”,是什么意思?他们后台用什么语言?
  17. Sql语法高级应用之四:使用视图实现多表联合数据明细
  18. log4j配置独立日志方法
  19. Xcode 7.0正式版发布了
  20. EJB介绍

热门文章

  1. 第十六周项目3:max带来的冲突
  2. systemverilog中堵塞和非堵塞事件以及同步
  3. Swift 字典的经常用法
  4. 英语音乐---二、Burning
  5. POJ 3279 枚举?
  6. Oracle 常用内置函数
  7. Python json数据中文输出问题。
  8. &lt;Three.js&gt;(第一节)环境搭建
  9. hdu 2018 - 递推
  10. python的模块导入机制