一、vector中的find 注意find不属于vector的成员,而存在于算法中,应加上头文件#include <algorithm> 1#include <vector>2#include <algorithm>3#include <iostream>4usingnamespacestd;5intmain( )6{7vector<int>L;8L.push_back(1);9L.push_back(2);10L.push_back(3);11L.push_back(4);12L.push_bac...
1.1 vector(数组)封装动态数组的顺序容器。 1.2 queue(队列)是容器适配器,他是FIFO(先进先出)的数据结构。 1.3 deque(双端队列)是有下标顺序容器,它允许在其首尾两段快速插入和删除。 1.4 set(集合)集合基于红黑树实现,有自动排序的功能,并且不能存放重复的元素。 1.5 unordered_set(无序集合)基于哈希表实现,...
若要删除std::vector中的element,正规的方式该用find() generic algorithm,若find()找到了,会传回该iterator,若找不到,将传回vector.end()。这种写法远比用for loop干净很多。 1 /* 2 (C) OOMusou 2006http://oomusou.cnblogs.com 3 4 Filename : VectorFindAndErase.cpp 5 Compiler : Visual C++ 8.0...
例如,STL用sort()来对一个vector中的数据进行排序,用find()来搜索一个list中的对象,函数本身与他们操作的数据的结构和类型无关,因此他们可以在从简单数组到高度复杂容器的任何数据结构上使用; 仿函数(Functor) 适配器(Adaptor) 分配器(allocator) 2.1 容器 STL中的容器有队列容器和关联容器,容器适配器(congtainer ...
算法(Algorithm),是用来操作容器中的数据的模板函数。例如,STL用sort()来对一个vector中的数据进行排序,用find()来搜索一个list中的对象,函数本身与他们操作的数据的结构和类型无关,因此他们可以在从简单数组到高度复杂容器的任何数据结构上使用; 仿函数(Functor) ...
毋庸质疑,lambda最大的一个优势是在使用STL中的算法 (algorithms) 库时: vector<string> address{'111','222',',333','.org','wwwtest.org'}; for_each(address.begin(),address.end(),[](conststring& str){cout<<str<<endl;}); 如此一行代码就可以循环打印容器的数据。
如果需要空间动态缩小,vector<Point>().swap(pointVec); //或者pointVec.swap(vector<Point> ()),vector的默认构造函数建立临时vector对象 如果vector中存放的是指针,那么当vector销毁时,这些指针指向的对象不会被销毁,内存也不会被释放,需要手动delete。
vector<int>::iterator iter; iter = dataVector.begin()+4; iter = std::advance(dataVector.begin(), 4); iter = std::next(dataVector.begin(), 4); 单例 class FSingle { public: static FSingle* getInstance() { static FSingle GlobalInstance; ...
strrchr(p, c)在字符串中从末尾开始反向查找指定字符,并返回从该字符开始到字符串末尾的子字符串地址 想要获取字符串从第n个字符开始的子串,用指针操作即可 char*str="123456789";//*(str+3)就是指的第4个字符'4' strstr(p, p1)查找字符串p1是否是p的子串,如果是返回首次出现的地址 ...
vector<vector<Point> > contours; // find squares in every color plane of the image for (int c = 0; c < 3; c++) { int ch[] = {c, 0}; mixChannels(&blurred, 1, &gray0, 1, ch, 1); // try several threshold levels