java中vector容器,vector向量容器(常用的使用方法总结)

关于STL中vector容器的学习,编译运行后边看代码,边看执行结果效果更佳,还是想说看别人的代码一百遍,不如自己动手写一遍。

vector向量容器不但能像数组一样对元素进行随机访问,还能随时在尾部插入元素,简单而高效,能够完全替代数组。

vector最大的亮点在于具有内存自动管理的功能,插入和删除元素时能够动态调整所占的内存空间。

值得注意的是,vector容器中的两个重要方法,begin()返回的是首元素位置的迭代器,end()返回的是最后一个元素的下一个元素位置的迭代器。

//关于STL中vector容器的学习,编译运行后边看代码,边看执行结果效果更佳,不过看别人的代码一百遍,不如自己动手写一遍

#include //头文件

#include

#include

using namespace std;

void print(vector v);

bool mycmpare(const int &a, const int &b){

return a>b;

}

int main ()

{

//创建vector对象三种常用的方式,此处存储元素类型是int,还可以是double、char、long long等基本数据类型,甚至是string基本字符序列容器

vector v1;//不指定容器的元素个数的定义一个用来存储整型的向量容器

cout<

print(v1);

/*运行结果

v1:

大小为:0

*/

vector v2();//指定容器的元素个数的定义一个大小为10的用来存储整型的向量容器,默认初始化为0

cout<

print(v2);

/*运行结果

v2:

大小为:5

0 0 0 0 0

*/

vector v3(,);//也可指定初始值,此处指定为1

cout<

print(v3);

/*运行结果

v3:

大小为:5

1 1 1 1 1

*/

//另外事先指定不指定大小都无所谓,指定了大小也可以随时使用push_back()对vector容器进行尾部扩张

v1.push_back();//向空的vector容器尾部扩张,追加元素为1

cout<

print(v1);

v3.push_back();//向已有元素的vector容器尾部扩张,追加元素为2

cout<

print(v3);

/*运行结果

v1:

大小为:1

1

v3:

大小为:6

1 1 1 1 1 2

*/

//插入元素使用insert()方法,要求插入的位置是迭代器的位置,而不是元素的下标

v3.insert(v3.begin(),);//在最前面插入3

cout<

print(v3);

v3.insert(v3.end(),);//在末尾追加3,此处等同于push_back()

cout<

print(v3);

/*运行结果

v3:

大小为:7

3 1 1 1 1 1 2

v3:

大小为:8

3 1 1 1 1 1 2 3

*/

int i;

for(i=;i < v3.size();i++){//只可赋值到已扩张位置

v3[i]=i;

}

//要删除一个元素或者一个区间中的所有元素时使用erase()方法

v3.erase(v3.begin()+);//删除第2个元素,从0开始计数

cout<

print(v3);

/*运行结果

v3:

大小为:7

0 1 3 4 5 6 7

*/

v3.erase(v3.begin()+,v3.begin()+);//删除第1个到第3个元素区间的所有元素

cout<

print(v3);

/*运行结果

v3:

大小为:5

0 4 5 6 7

*/

//由结果可知,erase()方法同insert()方法一样,操作的位置都只是迭代器的位置,而不是元素的下标

//要想清空vector(),使用clear()方法一次性删除vector中的所有元素

cout<

print(v2);

/*运行结果

v2:

大小为:5

0 0 0 0 0

*/

v2.clear();

if(v2.empty()) cout<

print(v2);

/*运行结果

v2经过使用clear()方法后为空

大小为:0

*/

//要想将向量中某段迭代器区间元素反向排列,则使用reverse()反向排列算法,需要添加algorithm头文件

cout<

print(v3);

reverse(v3.begin(),v3.end());//全部反向排列

cout<

print(v3);

/*运行结果

v3反向排列前:

大小为:5

0 4 5 6 7

v3反向排列后:

大小为:5

7 6 5 4 0

*/

//要想将向量中某段迭代器区间元素进行排序,则使用sort()算法

cout<

print(v3);

sort(v3.begin(),v3.end());//默认升序排列

cout<

print(v3);

/*运行结果

v3升序排列前:

大小为:5

7 6 5 4 0

v3升序排列后:

大小为:5

0 4 5 6 7

*/

//自定义排序比较函数,此处降序

cout<

print(v3);

sort(v3.begin(),v3.end(),mycmpare);

cout<

print(v3);

/*运行结果

v3降序排列前:

大小为:5

0 4 5 6 7

v3降序排列后:

大小为:5

7 6 5 4 0

*/

}

void print(vector v)

{

//cout<

cout<

int i;

for(i=;i< v.size();i++){

cout<

}

cout<

/*cout<

//定义迭代器变量it,类型与容器元素类型保持一致

vector::iterator it;

for(it=v.begin(); it != v.end(); it++){

cout<

}

cout<

}

学习笔记之vector向量容器

今天复习到vector向量容器,里面包括vector向量容器的一些优点以及具体的使用方法及代码,分享给大家. Vector向量容器不但能够像数组一样对元素进行随机访问,还可以在尾部插入元素,是一种简单 ...

vector向量容器

vector向量容器不但可以像数组一样对元素进行随机访问,还能在尾部插入元素,是一种简单高效的容器,可以代替数组. vector具有内存自动管理的功能,对于元素的插入和删除,可以动态的调整所占内存. ...

标准模板库使用参考——vector向量容器

C++的STL从广义上讲分为algorithm(算法),container(容器)和iterator(迭代器)三类,包含了诸多在计算机科学领域里所常用的基本数据结构和基本算法. 在C++标准库中,ST ...

C&plus;&plus;STL之vector向量容器

vector向量容器   vector向量容器不但能向数组一样对元素进行随机访问, 还能在尾部插入元素 vector具有内存自动管理的功能, 对于元素的插入和删除, 可动态调整所占的内存空间 vect ...

vector向量容器元素排序与查找

1.利用标准库函数sort()对vector进行排序 参考源码: #include #include vector

vector 向量容器用法祥解

vector(向量): C++中的一种数据结构,确切的说是一个类.它相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间的目的. 用法:         ...

利用copy函数简单快速输出&sol;保存vector向量容器中的数据

如果要输出vector中的数据我们可以通过循环语句输出,更加简便的方法是利用copy函数直接输出,例子: #include "stdafx.h" #include

C&plus;&plus; STL vector&lpar;向量容器&rpar;的使用(附完整程序代码)

一.简单介绍 Vectors 包括着一系列连续存储的元素,其行为和数组类似. 訪问Vector中的随意元素或从末尾加入元素都能够在O(1)内完毕,而查找特定值的元素所处的位置或是在Vector中插入元 ...

1&period;Vector&lpar;向量容器&rpar;

一.概述 Vectors 包含着一系列连续存储的元素,其行为和数组类似.访问Vector中的任意元素或从末尾添加元素都可以在常量级时间复杂度内完成,而查找特定值的元素所处的位置或是在Vector中插入 ...

随机推荐

Log4j配置详解&lpar;转&rpar;

一.Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出.综合使 ...

从零开始学 Java - CentOS 安装 JDK

我来总结一下吧 昨天我写了一篇从零开始学 Java - 我放弃了 .NET ?,在园子里突然引起了强烈的讨论,有期待我能持续更新的.有鼓励支持的.有相同经历的.也有同一个学校的师兄弟(我们相认了).当 ...

Leetcode Permutations

Given a collection of numbers, return all possible permutations. For example,[1,2,3] have the follow ...

HDU 3951 &lpar;博弈&rpar; Coin Game

先考虑两种简单的情况: 如果先手能一次把硬币拿完,即 k >= n ,那么先手胜 如果每次只能拿一个硬币, 即 k = 1 ,那么如果有奇数个硬币先手胜,如果有偶数个硬币后手胜. 剩下的情况就是 ...

学习动态性能表 v&dollar;sql

学习动态性能表 第三篇-(1)-v$sql V$SQL中存储具体的SQL语句. 一条语句可以映射多个cursor,因为对象所指的cursor可以有不同用户(如例1).如果有多个cursor(子游标)存 ...

Android开源项目发现--- 工具类数据库ORM篇(持续更新)

orm的db工具类,简化建表.查询.更新.插入.事务.索引的操作 1. greenDAO Android Sqlite orm的db工具类 项目地址:https://github.com/greenr ...

bootstrap 更改container 的width

参考:http://stackoverflow.com/questions/15884102/bootstrap-how-do-i-change-the-width-of-the-container ...

非交互式一句话添加root用户

useradd -p `openssl passwd -1 -salt ‘lsof’ admin123` -u 0 -o -g root -G root -s /bin/bash -d /usr/bi ...

Geany的&quot&semi;跳转到标记定义&OpenCurlyDoubleQuote;功能如何使用

Geany是个比较轻量级的代码编辑器,在一些不怎么需要编辑的代码上,我比较常用它来浏览代码.不过它的 跳转到标记定义(Go to tag definition) 功能有点奇怪,一开始死活不知道怎么用, ...

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/338221.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习C ,常见的误解

学习C 你是否会有以下几点误解&#xff1f;1. “要理解C &#xff0c;你必须先学习C”2. “C 是一门面向对象的语言”3. “为了软件可靠性&#xff0c;你需要垃圾回收”4. “为了效率&#xff0c;你必须编写底层代码”5. “C 只适用于大型、复杂的程序”如果你中*了&#xff0c…

openshift使用_OpenShift DIY:使用Gradle构建Spring Boot / Undertow应用程序

openshift使用由于此错误&#xff0c; Gradle 1.6是在OpenShift上运行的最后一个受支持的Gradle版本。 但是从Gradle 2.2开始&#xff0c;这不再是问题&#xff0c;因此&#xff0c;使用自己动手做墨盒&#xff0c;在OpenShift上运行最新的Gradle不再是问题。 DIY盒带是一种实验…

php管理智能dns,负载均衡之DNS轮询

域名注册商都支持对统一主机添加多条A记录&#xff0c;这就是DNS轮询&#xff0c;DNS服务器将解析请求按照A记录的顺序&#xff0c;随机分配到不同的IP上&#xff0c;这样就完成了简单的负载均衡。下图的例子是&#xff1a;有3台联通服务器、3台电信服务器&#xff0c;要实现“…

java ee jsp_EE JSP:使用自定义标签库生成动态内容

java ee jsp在Web应用程序中开发View层时&#xff0c;您希望尽量不要重复JSP文件中的内容。 JSP spec API允许您通过使用标记库来减少这种重复。 定制JSP标记是用户定义的xml标记元素&#xff0c;您可以将其插入JSP文件以替换为某些动态内容。 这是一个使用自定义JSP标记的简单…

php怎么把时间戳转成日期格式,php怎么把时间格式转换为时间戳?,时间戳转为日期...

php怎么把时间格式转换为时间戳&#xff1f;PHP怎么把时间格式转换成时间戳&#xff1f;&#xff0c;php时间格式转换为时间戳的方法&#xff1a;1。使用mktime()将时间转换为时间戳&#xff0c;语法为“mktime(小时、分钟、秒、月、日、年)”&#xff1b;2.使用strtime()将字符…

C语言的标识符由什么组成

C语言的标识符由字母、数字、下划线组成&#xff0c;并且第一个字符必须是字母或下划线&#xff0c;不能是数字。在标识符中&#xff0c;字母的大小写是有区别的&#xff0c;例如BOOK与book是两个不同的标识符。定义变量时&#xff0c;我们使用了诸如 a、abc、mn123 这样的名字…

jdk8读取文件_JDK 7和JDK 8中大行读取速度较慢的原因

jdk8读取文件我早些时候发布了博客文章Reading Large Lines Slower in JDK 7和JDK 8&#xff0c;并且在描述该问题的文章上有一些有用的评论 。 这篇文章提供了更多解释&#xff0c;说明为何该文章中演示的文件读取&#xff08;并由Ant的LineContainsRegExp使用 &#xff09;在…

oracle_sod,oracle geometry几何关系sdo_Geom.Relate介绍,

oracle geometry几何关系sdo_Geom.Relate介绍&#xff0c;sdo_Geom.Relate(sdo_Geometry1, ‘MASK’, sod_Geometry2, tolerance )&#xff1a;用于判断一个几何体与另一个几何体的关系&#xff0c;我们用于判断当前点是否在某一个面(省份面、县市面、乡镇面)上。参数说明&…

C 11 实现的 100行 线程池

C 线程池一直都是各位程序员们造轮子的首选项目之一。今天&#xff0c;小编带大家一起来看看这个轻量的线程池&#xff0c;本线程池是header-only的&#xff0c;并且整个文件只有100行&#xff0c;其中C 的高级用法有很多&#xff0c;很值得我们学习&#xff0c;一起来看看吧。…

oracle把多行合并成字符串,怎样将Oracle多行转换成字符串?

在做一些比较复杂的DB数据导出时&#xff0c;有时会要求“将不固定的多行数据组合成一个字符串返回”。例子&#xff1a;ISV Portal中就遇到了类似的情况&#xff0c;要求对于每一个APP&#xff0c;返回其所属的所有类目名称&#xff0c;类目名称之间用[,]隔开。本文就用此例子…

openshift使用_OpenShift v3:使用WildFly和MySQL的Java EE 7入门

openshift使用OpenShift是Red Hat的开源PaaS平台。 OpenShift v3 &#xff08;将于今年发布&#xff09;将提供使用Docker和Kubernetes运行微服务的整体体验。 以经典的Red Hat方式&#xff0c;所有工作都在OpenShift Origin的开源中完成。 这也将推动OpenShift Online和OpenSh…

c程序的基本组成单位是什么?

C程序是由函数构成的。函数是C程序的基本组成单位。一个C源程序中仅有一个main()函数,除main函数之外可以有若干个其它的函数。每个函数实现某一特定的操作。因此&#xff0c;函数是C程序的基本单位。一个函数由两部分组成&#xff1a;函数的说明部分。包括函数名、函数类型、函…

java多线程 异常处理_Java8多线程ForkJoinPool:处理异常

java多线程 异常处理引入Java8 lambda背后的主要动机之一是能够尽可能轻松地使用多核的能力&#xff08;请参阅精通Lambdas&#xff1a;多核世界中的Java编程 &#xff09;。 只需将代码从collection.stream()...更改为collection.parallelStream()...您就可以使用即时多线程&a…

C语言头文件 “ 细节 ”

很多事不深入以为自己懂了&#xff0c;但真正用到项目上&#xff0c;才发现了问题。曾以为自己写C语言已经轻车熟路了&#xff0c;特别是对软件文件的工程管理上&#xff0c;因为心里对自己的代码编写风格还是有自信的。(毕竟刚毕业时老大对我最初的训练就是编码格式的规范化处…

订阅号微信公众号历史文章爬虫php,一步步教你怎么打造微信公众号历史文章爬虫...

原标题&#xff1a;一步步教你怎么打造微信公众号历史文章爬虫开篇语&#xff1a;邓爷爷曾说过&#xff1a;不管黑猫白猫&#xff0c;逮到耗子就是好猫。不管我是凑的还是笨办法堆出来的&#xff0c;确实把批量导出微信公众号所有历史文章的这个功能给做出来了&#xff0c;而且…

oracle中悲观锁定_如何使用悲观锁定修复乐观锁定竞争条件

oracle中悲观锁定回顾 在我以前的文章中 &#xff0c;我解释了使用显式乐观锁定的好处。 然后我们发现&#xff0c;在很短的时间范围内&#xff0c;并发交易仍可以在我们当前交易被提交之前立即提交产品价格更改。 此问题可以描述如下&#xff1a; 爱丽丝拿产品 然后&#…

初学者宝典:C语言入门基础知识大全(中)

04常量在程序运行中&#xff0c;其值不能被改变的量称为常量。常量有5种类型&#xff1a;整型常量、实型常量、字符常量、字符串常量和符号常量。4.1 数值转换—数值的四种表现形式&#xff1a;①&#xff1a;二进制&#xff1a;所有数字由0,1构成&#xff0c;逢二进一&#xf…

linux命令创建硬链接,Linux终端命令接口(十一)硬链接与软连接

一、进入终端 输入 使用 ls -l 即可.示例:$ touch file1 # 创建新文件 file1$ touch file2 # 创建新文件 file2$ ln file1 file3 # 为 file1 创建硬链接 file3$ ls -ltotal 0-rw-r--r-- 2 root root 0 01-25 16:59 file1-rw-r--r-- 1 root root 0 01-25 17:00 f…

stateless_Spring Stateless State Security第3部分:JWT +社会认证

stateless我的Stateless Spring Security系列文章的第三部分也是最后一部分是关于将基于JWT令牌的身份验证与spring-social-security混合在一起的。 这篇文章直接建立在它的基础上&#xff0c;并且主要集中在已更改的部分上。 想法是使用基于OAuth 2的“使用Facebook登录”功能…

return在c语言中是什么意思

函数是C语言的基本构件&#xff0c;一个C程序可以由一个主函数和若干个子程序函数构成&#xff0c;由主函数调用其它子程序函数&#xff0c;其他子程序函数也可以互相调用。通常希望通过函数调用使主函数能得到一个确定的值&#xff0c;这就是函数的返回值。在C语言中通过函数实…