C++中的容器{vector、stack、queue、map、pair、set}

2024-05-14 05:48

本文主要是介绍C++中的容器{vector、stack、queue、map、pair、set},希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • vector向量
    • 1、头文件
    • 2、vector主要操作
    • 3、截取vector
  • stack栈
    • 1、头文件
    • 2、基本操作
  • queue队列
    • 1、头文件
    • 2、基本操作
  • map关联容器
    • 1、头文件
    • 2、基本操作
  • set集合容器
    • 特点
  • pair

vector向量

C++ vector 容器浅析

向量(Vector)是一个封装了动态大小数组的顺序容器(Sequence Container)。跟任意其它类型容器一样,它能够存放各种类型的对象。可以简单的认为,向量是一个能够存放任意类型的动态数组。

1、头文件

#include<vector>//首先在程序开头处加上以包含所需要的类文件vector
using namespace std;//还有一定要加上

2、vector主要操作

vector<int> test1;
cout<< sizeof(test1)<<endl;//16
cout << test1.size() << endl;//0vector<int> test3(5);
cout << sizeof(test3) << endl;//16
cout << test3.size() << endl;//5test1.push_back(1);//动态数组,输入元素:1
test3.push_back(1);//元素:0 0 0 0 0 1test1.pop_back();//无返回值,去掉最后一个元素

3、截取vector

vector<int>::const_iterator begin = num.begin();
vector<int>::const_iterator last = num.begin() + length;
vector<int> new_arr(begin, last);

stack栈

先进后出

1、头文件

#include <stack> 

2、基本操作

stack<int> S;
cout << sizeof(S) << endl;//20
cout <<boolalpha<< S.empty() << endl;//栈S为空,返回true
S.push(3);//3
S.push(7);//3 7
S.push(1);//3 7 1
cout << S.size() << " ";//栈大小为3cout << S.top() << " ";//输出栈顶元素:1
S.pop();//移除栈顶元素,剩余3 7cout << S.top() << " ";//输出栈顶元素:7
S.pop();//移除栈顶元素,剩余3cout << S.top() << " ";//输出栈顶元素:3
S.push(5);//3 5cout << S.top() << " ";//输出栈顶元素:5
S.pop();//移除栈顶元素,剩余3cout << S.top() << endl;//输出栈顶元素:3
cout << boolalpha << S.empty() << endl;//栈S不为空,返回false
S.emplace(2);

queue队列

先进先出

1、头文件

#include<queue>

2、基本操作

queue<int> Q;
cout << sizeof(Q) << endl;//20
cout << Q.size() << endl;//0
cout << boolalpha << Q.empty() << endl;//队列Q为空,返回trueQ.push(1);Q.push(2);Q.push(3);//队列:1 2 3
cout << Q.size() << endl;//3
cout << Q.front() << endl;//输出队首:1
Q.pop();//移除队首元素
cout << Q.front() << endl;//输出队首:2

输出栈中所有的元素

while (!Q.empty())
{cout>>Q.front();Q.pop();
}

map关联容器

C/C++ - Map (STL) 用法與心得完全攻略

1、头文件

#include<map>

2、基本操作

map<char, int> chineseNum;
chineseNum.insert(pair<char, int>('A', 0));
chineseNum['B'] = 1;map<char, int>::iterator iter;
iter = chineseNum.find('C'); //iter 为 end
iter = chineseNum.find('A');//取出key为'A'的键值对,iter 为 ('A', 0)
cout << iter->first << '\t' << iter->second << endl;int tmp = chineseNum['C'];//F不在map中,会将('F',0)添加进map,并返回0
cout << chineseNum.size() << endl;//3
if (chineseNum.find('C') != chineseNum.end())cout << 'C';//C//迭代器刪除
iter = chineseNum.find('C');
chineseNum.erase(iter);//用關鍵字刪除
int n = chineseNum.erase('B');//如果刪除了會返回1,否則返回0//用迭代器範圍刪除 : 把整個map清空
chineseNum.erase(chineseNum.begin(), chineseNum.end());
//等同於chineseNum.clear()

set集合容器

特点

set集合中不存在重复元素;
set集合中的元素都为有序排列,不管插入的顺序如何。
set不支持下标的操作

#include <set>  //引用头文件
set<float> _set; //定义
_set.insert(1.0); //插入
_set.insert(2.0);
_set.insert(1.00);
_set.insert(0.00);
set<float>::iterator itr = _set.begin();
float f = *itr;
itr = _set.find(0);
f = *itr;cout << *_set.rbegin(); //输出最后一个元素,默认最大

pair

pair <string,double> product1 ("tomatoes",3.25);
pair <string,double> product2;
pair <string,double> product3;product2.first ="lightbulbs"; // type of first is string
product2.second =0.99; // type of second is doubleproduct3 = make_pair ("shoes",20.0);

三十分钟掌握STL

这篇关于C++中的容器{vector、stack、queue、map、pair、set}的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/987916

相关文章

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

详解C++中类的大小决定因数

《详解C++中类的大小决定因数》类的大小受多个因素影响,主要包括成员变量、对齐方式、继承关系、虚函数表等,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 非静态数据成员示例:2. 数据对齐(Padding)示例:3. 虚函数(vtable 指针)示例:4. 继承普通继承虚继承5.

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准

如何将Tomcat容器替换为Jetty容器

《如何将Tomcat容器替换为Jetty容器》:本文主要介绍如何将Tomcat容器替换为Jetty容器问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat容器替换为Jetty容器修改Maven依赖配置文件调整(可选)重新构建和运行总结Tomcat容器替

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque