Vector使用方法简单整理
使用vector,需要引用vector库:
#include<vector>
首先,创建一个可以容纳int的vector变量——arr:
vector<int> arr;
接着,就可以使用一些vector的内建函数了:
arr.push_back();//在arr结尾插入数字9 arr.pop_back();//删除arr末尾最后一个项 arr.front();//arr的第一个项的值 arr.back();//arr的最后一个项的值 arr.begin();//arr的第一个项的指针 arr.end();//arr的最后一个项的指针 arr.size();//arr的实际长度 arr.erase(arr.begin(),arr.end());//删除从arr的第一个到最后一个项 arr.insert(arr.begin(),);//在arr的头之前插入数字5 arr.insert(arr.begin(),,);//在arr的头之前插入6个5 arr.empty();//判断arr是否为空 arr.clear();//将arr清空
Vector可以搭配一些算法使用,首先应用algorithm库:
#include<algorithm>
算法函数如下:
sort(arr.begin(),arr.end());//对vector排序 stable_sort(arr.begin(),arr.end());//对vector稳定排序 reverse(arr.begin(),arr.end());//反转vector vector<int>::iterator newend = unique(arr.begin(),arr.end()); //对arr去重,并把去重后的实际个数存在迭代器newend里面 arr.erase(newend,arr.end()); //把从newend到arr最后一项(即重复的数字)去除
附上完整测试代码:
#include<iostream> #include<vector> #include<algorithm> using namespace std; int main(){ cout<<"Vector functions:"<<endl; vector<int> arr; arr.push_back(); arr.push_back(); arr.push_back(); arr.push_back(); arr.push_back(); arr.push_back(); arr.push_back(); arr.push_back(); arr.push_back(); arr.push_back(); cout<<"arr.push_back() : "; ;i<arr.size();i++){ cout<<arr[i]<<" "; } cout<<endl; arr.pop_back(); cout<<"arr.pop_back() : "; ;i<arr.size();i++){ cout<<arr[i]<<" "; } cout<<endl; cout<<"arr.front() : "<<arr.front()<<endl; cout<<"arr.back() : "<<arr.back()<<endl; cout<<"arr.size() : "<<arr.size()<<endl; arr.erase(arr.begin()+,arr.end()); cout<<"arr.erase() : "; ;i<arr.size();i++){ cout<<arr[i]<<" "; } cout<<endl; arr.insert(arr.begin(),,); cout<<"arr.insert() : "; ;i<arr.size();i++){ cout<<arr[i]<<" "; } cout<<endl; cout<<endl<<endl<<"Algorithm functions:"<<endl; sort(arr.begin(),arr.end()); cout<<"sort():"; ;i<arr.size();i++){ cout<<arr[i]<<" "; } cout<<endl; reverse(arr.begin(),arr.end()); cout<<"reverse():"; ;i<arr.size();i++){ cout<<arr[i]<<" "; } cout<<endl; vector<int>::iterator oldend = arr.end(); vector<int>::iterator newend; newend = unique(arr.begin(),arr.end()); arr.erase(newend,oldend); cout<<"unique():"; ;i<arr.size();i++){ cout<<arr[i]<<" "; } cout<<endl; cout<<endl<<endl<<"Vector functions:"<<endl; cout<<"arr.empty() : "; if(arr.empty() == false){ cout<<"false"<<endl; } else{ cout<<"true"<<endl; } arr.clear(); cout<<"arr.clear() : "; ;i<arr.size();i++){ cout<<arr[i]<<" "; } cout<<endl; cout<<"arr.empty() : "; if(arr.empty() == false){ cout<<"false"<<endl; } else{ cout<<"true"<<endl; } }
补充说明:在C中,有很多东西需要自己实现。C++提供了标准模板库(Standard Template Libray,STL),其中封装了很多容器,不需要费力去实现它们的细节而直接调用函数来实现功能。vector是其中之一,vector指向量,可以理解为“变长数组”,长度根据需要而自动改变的数组。有时会碰到普通数组会超过内存的情况,可以使用vector解决。而且,vector可以用来以邻接表的方式存储图,可以解决当节点数太多,无法使用邻接矩阵,又害怕使用指针实现邻接表的时候,使用很简单。
Vector使用方法简单整理的更多相关文章
- .NET Web开发技术简单整理
在最初学习一些编程语言.一些编程技术的时候,做的更多的是如何使用该技术,如何更好的使用该技术解决问题,而没有去关注它的相关性.关注它的理论支持,这种学习技术的方式是短平快.其实工作中有时候也是这样,公 ...
- Support Vector Machine (1) : 简单SVM原理
目录 Support Vector Machine (1) : 简单SVM原理 Support Vector Machine (2) : Sequential Minimal Optimization ...
- 转载:.NET Web开发技术简单整理
在最初学习一些编程语言.一些编程技术的时候,做的更多的是如何使用该技术,如何更好的使用该技术解决问题,而没有去关注它的相关性.关注它的理论支持,这种学习技术的方式是短平快.其实工作中有时候也是这样,公 ...
- MYBATIS 简单整理与回顾
这两天简单整理了一下MyBatis 相关api和jar包这里提供一个下载地址,免得找了 链接:http://pan.baidu.com/s/1jIl1KaE 密码:d2yl A.简单搭建跑项目 2.进 ...
- IIS6.0 IIS7.5应用程序池自动停止的解决方法 搜集整理
来源:http://www.guchengnet.com/1499.html IIS6.0 IIS7.5应用程序池自动停止的解决方法 搜集整理 发表于2016年12月14日 有2.3个月没有用本地的i ...
- .NET Web开发技术简单整理 转
.NET Web开发技术简单整理 原文:http://www.cnblogs.com/SanMaoSpace/p/3157293.html 在最初学习一些编程语言.一些编程技术的时候,做的更多的是如何 ...
- 编程中遇到的Python错误和解决方法汇总整理
这篇文章主要介绍了自己编程中遇到的Python错误和解决方法汇总整理,本文收集整理了较多的案例,需要的朋友可以参考下 开个贴,用于记录平时经常碰到的Python的错误同时对导致错误的原因进行分析, ...
- MongoDB中insert方法、update方法、save方法简单对比
MongoDB中insert方法.update方法.save方法简单对比 1.update方法 该方法用于更新数据,是对文档中的数据进行更新,改变则更新,没改变则不变. 2.insert方法 该方法用 ...
- 操作文件方法简单总结(File,Directory,StreamReader,StreamWrite )
对于文件夹,文档的操作一直处于一知半解状态,有时间闲下来了,好好练习了一把,对文档,文件的操作有了一个基本的认知, 若要深入了解,还是得通过实际的项目才行了,好了废话不多说,上酸菜!! 注:红色标题为 ...
随机推荐
- 控制反转&依赖注入
IoC(Inversion of Control,控制反转).这是spring的核心,贯穿始终.所谓IoC,对于spring框架来说,就是由spring来负责控制对象的生命周期和对象间的关系.这是什么 ...
- Shell文件
#!/bin/bashecho "======================欢迎来到进爷故事会======================="echo "******* ...
- samba搭建与配置说明
1. 环境检查getenforce 检查selinux service iptables stop 2.安装samba yum -y install samba 3.配置samba /etc/samb ...
- Java编程思想:内部类其他知识点
public class Test { public static void main(String[] args) { // InheritInner.test(); // EggTest.test ...
- RabbitMQ 从入门到精通(二)
目录 1. 消息如何保障百分之百的投递成功? 1.1 方案一:消息落库,对消息状态进行打标 1.2 方案二:消息的延迟投递,做二次确认,回调检查 2. 幂等性 2.1 幂等性是什么? 2.2 消息端幂 ...
- tomcat用做图片服务器
最近做了个小网站,就是用tinyce富文本编辑器,https://www.511easy.com/ 保持字体排版和图片 发现博客园的图片,一天之后就无法显示 就想着自己做一个图片服务器,上传图片到指定 ...
- Eclipse Spring框架配置
1.从官网下载相应的jar包 (1)下载spring framework包,地址: https://repo.spring.io/webapp/#/artifacts/browse/tree/Gene ...
- 微信小程序设计总结
微信小程序是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验. 小程序提供了一个简单.高效的应用开发框架和丰富的组件及API,帮助开发者在微信中开发具有原生 A ...
- ACM线性基学习笔记
https://www.cnblogs.com/31415926535x/p/11260897.html 概述 最近的几场多校出现了好几次线性基的题目,,会想起之前在尝试西安区域赛的一道区间异或和最大 ...
- internet连接共享被启用时 出现了一个错误 (null)
服务Firewall和Internet Sharing Service都已启动还是出现此问题 注意到点选允许共享时的提示:当前已为wireless_95364开启...... 随便选一个别的适配器,开 ...