#include <iostream>
#include <vector>
#include <algorithm>
#include <numeric>
using namespace std; bool findCondition(int x)
{
return x%2==0;
} //仿函数
template<typename T>
struct display{
void operator()(const T &x)const
{
cout<<x<<" ";
}
}; int main()
{ int i; vector<int> iv;//vector 追加和随机访问效率高,插入删除效率低 int ia[]={0,1,2,3,4,5,6,6,6,7,8};
vector<int> iv2(ia,ia+sizeof(ia)/sizeof(int)); //数组转换成向量
for_each(iv2.begin(),iv2.end(),display<int>());
cout<<endl; iv.push_back(1);
iv.push_back(2);
iv.push_back(3);
iv.push_back(4);
iv.push_back(5);
iv.pop_back(); //推出 5 ,返回void for_each(iv.begin(),iv.end(),display<int>());
cout<<endl; cout<<"元素的数量"<<iv.size()<<"容量"<<iv.capacity()<<endl; //随机读写
iv[0] = 99;
cout<<iv[0]<<endl; vector<int>::iterator it,it2;
it=iv.begin();//iv.begin()指向第一个元素
iv.insert(it,3,-1);//在it所指的单元前插入3个-1 it=iv.end()-1;//iv.end()指向了下一个最后一个元素的下一个元素
iv.erase(it);//删掉倒数第1个元素,也可以删除区间的元素
cout<<"迭代器输出 "<<*it<<endl;//输出的是刚才那个被删掉的元素4,也就是说删掉元素之后,it并没有改变,而且指向了一个被删除的元素 iv2.assign(iv.begin(),iv.end());//复制iv到iv2
if(iv==iv2)
{
cout<<"iv == iv2"<<endl;
}
iv2.clear();//删除容器中的所有元素,iv.size()变成0,而iv.capacity()不变,也就是内存并未归还给OS
iv2.swap(vector<int>());//iv.capacity()也变为0,删除并归还内存给OS的常用方法 //非变异算法
it = find(iv.begin(),iv.end(),3);//在[first,last)(闭开区间)上查找等于3值的元素
if(it==iv.end()){
cout<<"Not found 3"<<endl;
}else{
cout<<"Found in iv["<<it-iv.begin()<<"]"<<endl;
} it = find_if(iv.begin(),iv.end(),findCondition);//查找被2整除的元素
if(it==iv.end()){
cout<<"Not found %2"<<endl;
}else{
cout<<"Found in iv["<<it-iv.begin()<<"]"<<endl;
} cout<<"count -1 is "<<count(iv.begin(),iv.end(),-1)<<endl; //求和,第三个值0是用于函数辨识数据类型
cout<<"sum = "<<accumulate(iv.begin(),iv.end(),0)<<endl;
//string sum = accumulate(v.begin() , v.end() , string(" "));这个可以把向量字符串连接起来 //变异算法
cout<<"翻转 前";
for_each(iv.begin(),iv.end(),display<int>());
cout<<endl;
reverse(iv.begin(),iv.end());
cout<<"翻转 后";
for_each(iv.begin(),iv.end(),display<int>());
cout<<endl; replace(iv.begin(),iv.end(),-1,200);//将所有的-1替换成200
fill_n(iv.begin(),3,44);//在开头填充3个44,如果空间不足就会报错
fill_n(iv.begin()+4,2,2);
//generate_n(iv.begin(),5,rand);//条件填充
//it = remove_if(iv.begin(),iv.end(),findCondition);//删除条件内的元素,依次填充到头,然后返回一个it,这个it是尾部,实际的iv.size()是不变的
cout<<"unique 前的值"<<endl;
for_each(iv.begin(),iv.end(),display<int>());
cout<<endl;
it = unique(iv.begin(),iv.end());//只是把唯一的元素全部移到了前面,iv的值并不改变
cout<<"unique 后的值"<<endl;
for_each(iv.begin(),iv.end(),display<int>());
cout<<endl;
for(it2=iv.begin();it2!=it;it2++)
{
cout<<*it2<<endl;
}
cout<<iv.size()<<" 2 "<<iv2.size()<<endl;
unique_copy(iv.begin(),iv.end(),back_inserter(iv2));//将结果拷贝到iv2,并且iv2要有足够的空间,所以这里需要back_inserter。
for_each(iv2.begin(),iv2.end(),display<int>());
cout<<endl;
//排序算法 //转换成堆,排序
make_heap(iv.begin(),iv.end());
sort_heap(iv.begin(),iv.end()); sort(iv.begin(),iv.end());//等同于sort(vect.begin(), vect.end(), less<int>() );降序排序sort(iv.begin(),iv.end(),greater<int>());
stable_sort(iv.begin(),iv.end());//使相同的值在原来的位置不变,参数传入的是结构体时,会发现两者之间的明显区别
partial_sort(iv.begin(),iv.begin()+4,iv.end());//取top4
random_shuffle(iv.begin(),iv.end());//打乱顺序 for (i=0;i<iv.size();i++)
{
cout<<"0+"<<iv[i]<<endl;
}
cout<<"元素的数量"<<iv.size()<<endl; return 0;
}

STL基础1:vector的更多相关文章

  1. 【STL基础】vector

    vector 构造函数: //default: vector<T> v; //空的vector //fill: vector<T> v(n); //n个元素的vector,元素 ...

  2. 转:用STL中的vector动态开辟二维数组

    用STL中的vector动态开辟二维数组 源代码:#include <iostream>#include <vector>using namespace std;int mai ...

  3. STL基础复习

    stl容器:vector,deque,list,map/multimap,set 特殊容器:stack,queue,priority_queue 通用操作 size()  返回当前容器元素数量 emp ...

  4. STL基础--基本介绍

    为什么要使用C++标准库 /* * 为什么使用C++标准库: * 1. 代码重用,不用重新造轮子 * 2. 效率(快速,且使用更少的资源). 现代C++编译器经常对C++标准库的代码有优化 * 3. ...

  5. 【c++基础】vector初始化的几种方式

    前言 STL中的vector有几种初始化方式,根据不同的需求选择合适的初始化方式. 源码 // constructing vectors #include <iostream> #incl ...

  6. STL中的Vector相关用法

    STL中的Vector相关用法 标准库vector类型使用需要的头文件:#include <vector>. vector 是一个类模板,不是一种数据类型,vector<int> ...

  7. (转)C++ STL中的vector的内存分配与释放

    C++ STL中的vector的内存分配与释放http://www.cnblogs.com/biyeymyhjob/archive/2012/09/12/2674004.html 1.vector的内 ...

  8. C++STL中的vector的简单实用

    [原创] 使用C++STL中的vector, #include <stdio.h> #include<stdlib.h> #include<vector> usin ...

  9. STL中的vector实现邻接表

    /* STL中的vector实现邻接表 2014-4-2 08:28:45 */ #include <iostream> #include <vector> #include  ...

  10. 2.1实现简单基础的vector

    2.1实现简单基础的vector 1.设计API 我们参考下C++ <std> 库中的vector, vector中的api很多,所以我们把里面用的频率很高的函数实现; 1.1 new&a ...

随机推荐

  1. Java基础学习笔记(四)

    21.构造方法(续):分类: 隐式构造方法:如果在一个类中,没有手动编写构造方法,则系统会提供一个默认的无参的构造方法 显式构造方法:如果在一个类中,手动编写构造方法,则系统不会提供默认的无参的构造方 ...

  2. 最完整Android Studio插件整理 (转)

    转自:http://blog.csdn.net/alpha58/article/details/62881144 现在Android的开发者基本上都使用android Studio进行开发(如果你还在 ...

  3. 第四章 栈与队列(c1)栈应用:进制转换

  4. c++:空构造空析构的益处之一

    项目开发过程中发现一个问题,有段代码,一个动态库的cpp代码里不包含头文件中类的空构造空析构实现,就会出现编译出的动态库依赖项少了很多.而添加后则多了好几个依赖项.下面看例子: ##a.h class ...

  5. HDU-1069.MonkeyandBanana(LIS)

    本题大意:给出n个长方体,每种长方体不限量,让你求出如何摆放长方体使得最后得到的总高最大,摆设要求为,底层的长严格大于下层的长,底层的宽严格大于下层的宽. 本题思路:一开始没有啥思路...首先应该想到 ...

  6. VM虚拟机 安装linux系统

    首先需要下载VMware10 和CentOS-6.4,我这边提供了百度网盘,可供下载链接:https://pan.baidu.com/s/1vrJUK167xnB2JInLH890fw 密码:r4jj ...

  7. lombok ------让代码更简洁方便

    估计在平常写代码中,都会创建entity类的实体来,都是那种创建变量,生成set get 方法,方便外部调用,你以为你很流利的操作快捷键就很方便的了? 其实不然,有一个lombok 工具可以帮我们自动 ...

  8. mongodb导入csv结构化数据

    csv数据样本 "103238704","","-jmyuncker@aol.com-","-r4Vp5iL2VbM=-" ...

  9. 梦殇 chapter three

    chapter three 悲伤有N个层面.对于生命是孤独的底色,对于时间是流动的伤感,对于浪漫是起伏的变奏,对于善和怜悯是终生的慨叹…… 出去和舍友买完东西,刚回到宿舍,舍友就说,刚才有人给你打电话 ...

  10. MVC和Web API的区别

    最近几次面试时碰到过面试官提问这个问题.我一开始觉得这两个根本没有可比性,其中有一位面试官说,有不同啊,比如继承的基类不同,webapi继承的事APIController,等等. 今天我就总结一下,其 ...