C++ 标准模板库 STL(4)vector 与 deque

一、STL vector类

1.1 vector特点

        vector提供动态数组的通用功能,具体有如下特点:

  • 在数组末尾添加和删除元素所需时间固定。
  • 在数组中间添加或删除元素所需时间与该元素后面的元素个数成正比。
  • 存储的元素数是动态的,而vector类负责管理内存。

1.2 vector操作

        vector初始化操作可选择以下几种方式:

#include <vector>

// 实例化vector
std::vector<int> vec;
std::vector<float> vec;

// 声明迭代器
std::vector<int>::const_iterator element;

// 创建带有初值的vector
std::vector<int> vec {202, 107, -1};
std::vector<int> vec = {202, 107, -1};

// 创建具有初始大小的vector
std::vector<int> vec(5);

// 设置初始大小为5, 并赋初值为10
std::vector<int> vec(5, 10);

        vector插入操作可以使用push_back()在末尾插入元素,使用pop_back()删除末尾元素。

#include <vector>

std::vector<int> vec;

// 向数组中插入元素1
vec.push_back(1);

// 删除末尾元素
vec.pop_back();

        vector可以使用insert()在指定的位置插入元素。

#include <vector>

std::vector<int> vec = {1, 2, 3};

vec.insert(vec.begin(), 25); // 当前元素为25, 1, 2, 3

vec.insert(vec.end(), 2, 50); // 当前元素为25, 1, 2, 3, 50, 50

std::vector<int> tmp = {100, 200};

vec.insert(vec.begin()+1, tmp.begin(), tmp.end()); //当前元素为25, 100, 200, 1, 2, 3, 50, 50

        vector可以使用[]访问其中的元素,也可以使用迭代器访问其中的元素。

#include <vector>

std::vector<int> vec = {1, 2, 3};

std::cout << vec[0] << std::endl; // 输出1

vector<int>::const_iterator element = vec.cbegin();

std::cout << *(element + 1) << std::endl; // 输出2

        vector的大小指的是实际存储的元素数,而vector的容量指的是在重新分配内存以存储更多元素前vector能够储存的元素数。因此,vector的大小≤容量。

#include <vector>

std::vector<int> vec(5, 0);

// 输出5, 5
std::cout << vec.size() << ", " << vec.capacity() << std::endl;

// 插入元素
vec.push_back(50);

// 插入元素前vec的容量为5, 不足以存储50, 因此需要重新分配内部缓冲区
// 重新分配的逻辑是智能的, 为避免插入下一个元素时再次重新分配, 提前分配了比当前需求更大的容量

// 输出6, 7
std::cout << vec.size() << ", " << vec.capacity() << std::endl;

二、STL deque类

        deque与vector非常类似,但支持在数组开头和末尾插入或删除元素。插入和删除同样支持push_back()和pop_back(),也支持使用[]访问数组中的元素。除此之外,它还允许push_front()和pop_front()在开头插入和删除元素。这些函数的具体用法与vector一致。

  • 13
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: C++ 标准模板STL)是一个强大的工具,为程序员提供了许多可以直接使用的容器、算法和迭代器。《C++ 标准模板编程实战》这本书集中讲解了 STL 的使用方法和实战技巧,旨在帮助读者开发出高效且易于维护的 C++ 程序。 这本书共分为四个部分。第一部分介绍了 STL 的基础知识,主要包括容器、迭代器、算法、函数对象等内容。第二部分重点讲解了序列容器和关联容器,以及它们常见的应用。第三部分主要是算法,详细介绍了 STL 中常用的算法,并且通过实例演示了其使用方法。第四部分主要是 STL 的高级应用,如智能指针、异常处理、多线程等。 此外,这本书还提供了大量的实战案例,这些案例既包括独立的小应用程序,也包括较为完整的项目代码。通过这些案例,读者可以深入了解 STL 的使用和设计思路,并掌握一些实用的编程技巧。 总的来说,这本《C++ 标准模板编程实战》是一本非常实用的书籍,不仅适合初学者入门,也适合有一定经验的开发者进一步提高自己的编程技能。建议读者在学习这本书时,可以边读边动手实践,更好地理解和掌握其中的内容。 ### 回答2: c++标准模板编程实战是一本非常经典、详实的c++ STL实战教材,主要讲解了STL的各种容器、算法和迭代器的常用操作和实现原理,并且通过大量的实例演示了STL在真实项目中的实际应用。 本书总共分为10个章节,前两章是介绍STL的基础知识和核心组件,包括迭代器、容器、算法等;第三章是介绍序列容器,主要包括vector、list、deque、stack、queue、heap、priority_queue和bitset等;第四章是介绍关联容器,主要包括set、multiset、map、multimap等;第五章是介绍迭代器,包括迭代器分类,迭代器实现方式和应用场景等;第六章是介绍函数对象,包括函数对象的定义、STL内置函数对象、自定义函数对象和函数对象适配器等;第七章是介绍算法基础,包括常用算法和自定义算法的实现;第八章是介绍字符串,在字符串操作方面,STL提供了string和wstring类,以及一些与之相关的算法;第九章是介绍STL的高级用法,包括元编程、策略模式、继承体系、嵌套类和allocator等;第十章是介绍STL和相关技术的未来发展趋势和发展方向。 总的来说,c++标准模板编程实战是一本非常好的STL实战教材,既可以作为初学者入门的指南,也可以作为中高级程序员巩固和深入学习STL的参考书。无论是学习STL的基础知识、习惯性使用STL容器和算法,还是在项目中灵活高效地应用STL,都会受益匪浅。 ### 回答3: c标准模板STL)是一组C++模板类和函数的集合,可以让程序员使用一些高效的算法数据结构,从而降低了开发者的工作量,提高了C++程序的效率和可维护性。 《C++标准模板编程实战》是一本介绍STL的经典教材,全书共分为25个章节,内容涉及到STL的迭代器、算法、容器、函数对象、适配器等方面。可谓是STL入门的重要读物。 该书的编写思路以工程实践为导向,讲解一些常用的数据结构算法的实现过程,并给出了一些标准中经典的函数的代码实现。例如,生成随机数的代码、字符串排序的代码、实现二叉堆的代码等等。这些代码可以帮助开发者更好地理解STL中的模板类和函数的实现原理和效率。 此外,该书对STL算法进行了详细介绍,包括容器、迭代器、函数对象等方面的应用。为了方便程序员,书中还提供了一些实用的STL程序的代码,例如STL的多个容器和关联式容器,还有STL中提供的适配器等。 总之,《C++标准模板编程实战》是学习STL的必备参考书,不仅深入浅出地讲解了STL的实现原理和应用,更是教会了我们如何将STL运用到工程中,将编程变得更加高效和简单。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值