C++ Primer 第三章 标准库类型vector+迭代器iterator 运算

时间:2023-01-16 11:00:28

1.vector:

标准库类型vector表示对象的集合,其中所有对象的类型都相同,集合中的每个对象都有一个与之对应的索引,索引用于访问对象。因为vector“容纳着”其他对象,所以它也常被称作容器(container)。

详细介绍:(1)矢量:具有方向性的量。
     (2) 编程语言方面:vector是C++标准模板库中的部分内容,中文偶尔译作“容器”,但并不准确。它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库。vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据。
2.迭代器

迭代器提供对一个容器中的对象的访问方法,并且定义了容器中对象的范围。迭代器就如同一个指针。事实上,C++的指针也是一种迭代器。但是,迭代器不仅仅是指针,因此你不能认为他们一定具有地址值。例如,一个数组索引,也可以认为是一种迭代器。

迭代器有各种不同的创建方法。程序可能把迭代器作为一个变量创建。一个STL容器类可能为了使用一个特定类型的数据而创建一个迭代器。作为指针,必须能够使用*操作符类获取数据。你还可以使用其他数学操作符如++。典型的,++操作符用来递增迭代器,以访问容器中的下一个对象。如果迭代器到达了容器中的最后一个元素的后面,则迭代器变成past-the-end值。使用一个past-the-end值得指针来访问对象是非法的,就好像使用NULL或为初始化的指针一样。

下面用一段手打代码来详细说明标准库vector:

 //对象的集合的标准库类型vector
#include <iostream>
#include <vector>
#include <string>
using namespace std;
int main()
{
vector <int> ivec1;
vector <int> ivec2(ivec1);//把ivec1拷贝到ivec2;
vector <int> ivec3=ivec1;//同上式意思一样; vector <int> ivec4(,);//元素为10个1;
vector <string> ivec5(,"a");//元素为10个"a"; vector<int> vec;
for(auto i=; i<; i++)
{
vec.push_back(i);//将i压入到vec,使vec[i] = i;
} for(unsigned int i=; i<vec.size(); i++)
{
cout<<"初始化遍历:"<<vec[i]<<endl;//采用下标形式遍历
} vector<int>::iterator it;//it初始化为一个迭代器
for(it = vec.begin(); it!=vec.end(); it++)
{
cout<<"迭代遍历:"<<*it<<endl;//采用迭代器形式遍历
} vec.insert(vec.begin()+,);//vector插入元素,第五个元素插入为0;
for(unsigned int i=; i<vec.size(); i++)
{
cout<<"插入遍历:"<<vec[i]<<endl;
} vec.erase(vec.begin()+);//vector删除元素,删除第三个元素;
for(unsigned int i=; i<vec.size(); i++)
{
cout<<"擦除遍历:"<<vec[i]<<endl;
}
vec.erase(vec.begin()+,vec.begin()+);//vector删除元素,删除从第四个元素到第8个元素,第8个元素不删除 for(vector<int>::iterator it = vec.begin(); it!=vec.end(); it++)
{
cout<<"迭代遍历:"<<*it<<endl;
} system("pause");
return ;
}

结果图:

C++ Primer 第三章 标准库类型vector+迭代器iterator 运算

C++ Primer 第三章 标准库类型vector+迭代器iterator 运算的更多相关文章

  1. C&plus;&plus;primer第三章标准库类型

    除第二章介绍的基本数据类型外,C++ 还定义了一个内容丰富的抽象数据类型标准库. 本章将介绍标准库中的 vector.string 和 bitset 类型. string 类型支持长度可变的字符串 v ...

  2. C&plus;&plus; Primer 第三章 标准库类型string运算

    1. 标准库类型 string string表示可变长的字符序列,使用string必须首先包含string头文件.如何初始化类的对象是由类本身决定的. int n; string s1;//默认初始化 ...

  3. c&plus;&plus; primer 第三章 标准库类型

    1. string 标准库 1.1初始化 string s1; 默认构造函数s1为空 string s2(s1); 将s2初始化为s1的一个副本 string s3("value" ...

  4. C&plus;&plus; Primer笔记1&lowbar;转义字符&lowbar;标准库类型string&lowbar;标准库类型vector

    1.转义字符 一般有两种方式: \x后紧跟1个或多个十六进制数字.或\后紧跟1.2.3个八进制数字,当中数字部分是字符相应的数值. #include <iostream> using na ...

  5. 标准库类型vector

    标准库类型vector表示对象的集合,其中所有对象的类型都相同.集合中的每个对象都有一个与之对应的索引,索引用于访问对象.因为vector“容纳着”其他对象,所以它被称为容器. 要想使用vector, ...

  6. C&plus;&plus; Primer 学习笔记&lowbar;6&lowbar;标准库类型 -- 命名空间using与string类型

     标准库类型(一) --命名空间using与string类型 引: 标准库类型是语言组成部分中更主要的哪些数据类型(如:数组.指针)的抽象! C++标准库定义的是高级的抽象数据类型: 1.高级:由 ...

  7. C&plus;&plus;标准库类型vector及迭代器iterator简介

    Vector是C++标准库类型,称为容器,一个容器中的所有对象必须是同一种类型的.与数组相比,其最大的优点就是动态增长.Vector是一个类模板,并不是数据类型,而vector<int>和 ...

  8. C&plus;&plus; primer读书笔记 chapter3 标准库类型

    除第二章介绍的是C++的基本类型,本章将大致介绍一下C++定义的内容丰富的抽象数据库类型标准库.着重介绍一下sting.vector和bitset. 3.2标准库string类型 1.string类型 ...

  9. 《C&plus;&plus; Primer 4th》读书笔记 第3章-标准库类型

        原创文章,转载请注明出处:http://www.cnblogs.com/DayByDay/p/3911534.html

随机推荐

  1. HBase 常用Shell命令

    两个月前使用过hbase,现在最基本的命令都淡忘了,留一个备查~ 进入hbase shell console$HBASE_HOME/bin/hbase shell如果有kerberos认证,需要事先使 ...

  2. radius服务器搭建

    yum install -y unzip gcc-c++ cd /opt unzip release-stable.zip mv ToughRADIUS-release-stable toughrad ...

  3. Jquery基础知识;

    1.jquery语法 jQuery 语法是通过选取 HTML 元素,并对选取的元素执行某些操作. 基础语法: $(selector).action() 美元符号定义 jQuery 选择符(select ...

  4. str、&lowbar;&lowbar;str&lowbar;&lowbar; 、repr、 &lowbar;&lowbar;repr&lowbar;&lowbar;、&grave;&grave;

    内建函数str()和repr() 或反引号操作符(``)可以方便地以字符串的方式获取对象的内容.类型.数值属性等信息. str()函数得到的字符串可读性好(故被print调用),而结果通常无法用eva ...

  5. android 上传图片到服务器Tomcat&lpar;Struts2&rpar;

    在做android开发的时候,有时你会用到图片的上传功能,在我的android项目中,我是选中图片,点击上传多张图片 android客户端上传图片部分的代码如下: package com.exampl ...

  6. MAC Mysql 重置密码

    使用mac电脑,当mysql登录密码忘记时,需要重置密码.步骤如下: 1. 关闭当前正在运行的mysql进程. A.进入"偏好设置",选择mysql, 再选"stop m ...

  7. JS--我发现,原来你是这样的JS:面向对象编程OOP&lbrack;2&rsqb;--&lpar;创建你的那个对象吧&rpar;

    一.介绍 我们继续面向对象吧,这次是面向对象编程的第二篇,主要是讲创建对象的模式,希望大家能从博客中学到东西. 时间过得很快,还是不断的学习吧,为了自己的目标. 二.创建对象 1.前面的创建对象方式 ...

  8. Fibonacci Modified

    题目来源:Fibonacci Modified We define a modified Fibonacci sequence using the following definition: Give ...

  9. 我的小游戏上线海外AppStore完整流程心得

    1,购买一台Mac或者用VMWare 安装Mac OS流程,笔者使用VMWare. 先安装Mac OS 10.13,教程,成功后不要着急安装vmtools, 首先更新系统至最新版,因为真机测试往往需要 ...

  10. 2&period; 自动化运维系列之Cobbler给Openstack节点安装操作系统。

    preface 我们在一篇博文知道了如何搭建Cobbler,那么下面就通过Cobbler来安抓Openstack所有节点吧. 服务器配置信息如下: 主机名 IP 角色 Cobbler.node.com ...