我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C++常见容器如何使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C++常见容器如何使用

本文小编为大家详细介绍“C++常见容器如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++常见容器如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    1.概述

    C++容器属于STL(标准模板库)中的一部分(六大组件之一),从字面意思理解,生活中的容器用来存放(容纳)水或者食物,东西,而C++中的容器用来存放各种各样的数据,不同的容器具有不同的特性,下图(思维导图)中列举除了常见的几种C++容器,而这部分C++的容器与python中的序列有很多相似之处,也许这也很好地印证了江湖上“C生万物”的说法。

    2.容器详解

    2.1vector(向量)

    从这个命名就可以很好地理解,在线性代数中,向量是一维的结构,而在容器中,向量也是看似一维的存储形式。可以理解为长度可变的数组。只不过在尾部增删数据的时候效率最高,其他位置增删数据则效率较低。举个例子(开胃菜):

    #include <iostream> #include <vector> using namespace std;// 程序的主函数int main(){vector<int> V;V.push_back(1);V.push_back(2);V.push_back(1);V.push_back(2);cout << V[0] << endl;system("pause");return 0;}

    打印输出:1

    从上面的例子可以看出,向量和数组的用法极其类似。当然,容器还有一个极其好用的功能,就是容器的嵌套使用。

    #include <iostream> #include <vector> using namespace std;// 程序的主函数int main(){vector<vector<int>> V;vector<int> sub_V;sub_V.push_back(1);sub_V.push_back(2);sub_V.push_back(1);V.push_back(sub_V);cout << V[0][1] << endl;system("pause");return 0;}

    打印输出2这个时候的向量可以看作是一个二维数组,当然比二维数组更加灵活、强大。

    当然向量容器还有其他更加丰富的操作。比如:

        int size = vec1.size();         //元素个数    bool isEmpty = vec1.empty();    //判断是否为空    vec1.insert(vec1.end(),5,3);    //从vec1.back位置插入5个值为3的元素    vec1.pop_back();              //删除末尾元素    vec1.erase(vec1.begin(),vec1.end());//删除之间的元素,其他元素前移    cout<<(vec1==vec2)?true:false;  //判断是否相等==、!=、>=、<=...    vector<int>::iterator iter = vec1.begin();    //获取迭代器首地址    vector<int>::const_iterator c_iter = vec1.begin();   //获取const类型迭代器    vec1.clear();                 //清空元素

    举个最常见的例子:

    #include <iostream> #include <vector> using namespace std;// 程序的主函数int main(){vector<int> V;V.push_back(1);V.push_back(2);V.push_back(3);for (vector<int>::iterator it = V.begin(); it != V.end(); it++)cout << *it << " ";cout << endl;cout << "==========================" << endl;V.insert(V.begin() + 2,10);for (vector<int>::iterator it = V.begin(); it != V.end(); it++)cout << *it << " ";system("pause");return 0;}

    注意如果不是在其尾部插入数据,要传入插入位置的迭代器。

    打印输出:

    C++常见容器如何使用

    2.2deque(双端队列)

    deque,顾名思义,从前后两端都可以进行数据的插入和删除操作,同时支持数据的快速随机访问。举个例子:

    #include <iostream> #include <deque> using namespace std;// 程序的主函数int main(){deque<int> D;D.push_back(1);D.push_back(2);D.push_back(3);for (deque<int>::iterator it = D.begin(); it != D.end(); it++)cout << *it << " ";cout << endl;cout << "============在其索引2的位置插入10:" << endl;D.insert(D.begin() + 2,10);for (deque<int>::iterator it = D.begin(); it != D.end(); it++)cout << *it << " ";cout << endl;cout << "============在其头部插入0:" << endl;D.push_front(0);for (deque<int>::iterator it = D.begin(); it != D.end(); it++)cout << *it << " ";cout << endl;cout << "============在其头部弹出0:" << endl;D.pop_front();for (deque<int>::iterator it = D.begin(); it != D.end(); it++)cout << *it << " ";system("pause");return 0;}

    打印输出:

    C++常见容器如何使用

    2.3list(列表)

    列表是用双向链表实现的,所谓的双向链表,指的是既可以从链表的头部开始搜索找到链表的尾部,也可以进行反向搜索,从尾部到头部。这使得list在任何位置插入和删除元素都变得非常高效,但是随机访问速度变得非常慢,因为保存的地址是不连续的,所以list没有重载[]运算符,也就是说,访问list元素的时候,再也不像向量和双端队列那么方便,不可以像我们以前在C语言的时候,访问数组那样对其元素进行访问。
    一起来看个例子:

    #include <iostream> #include <list> using namespace std;// 程序的主函数int main(){//list的创建和初始化list<int> lst1;          //创建空listlist<int> lst2(3);       //创建含有三个元素的listlist<int> lst3(3, 2); //创建含有三个元素的值为2的listlist<int> lst4(lst3);    //使用lst3初始化lst4list<int> lst5(lst3.begin(), lst3.end());  //同lst4cout << "lst4中的元素有:" << endl;for (list<int>::iterator it = lst4.begin(); it != lst4.end(); it++)cout << *it << " ";cout << endl;cout << "lst5中的元素有:" << endl;for (list<int>::iterator it = lst5.begin(); it != lst5.end(); it++)cout << *it << " ";cout << endl;system("pause");return 0;}

    运行,打印输出:

    C++常见容器如何使用

    然后再来看一个元素的添加,排序的例子。

    #include <iostream> #include <list> #include <vector> using namespace std;// 程序的主函数int main(){//list的创建和初始化list<int> lst1;          //创建空listfor(int i = 0; i < 10; i++)lst1.push_back(9-i);                    //添加值cout << "lst1中的元素有:" << endl;for (list<int>::iterator it = lst1.begin(); it != lst1.end(); it++)cout << *it << " ";cout << endl;cout << "对lst1中的元素进行排序:" << endl;lst1.sort();for (list<int>::iterator it = lst1.begin(); it != lst1.end(); it++)cout << *it << " ";cout << endl;cout << "在索引为5的地方插入999:" << endl;list<int>::iterator insert_it = lst1.begin();for (int i = 0; i < 5; i++)insert_it++;lst1.insert(insert_it, 3, 999);for (list<int>::iterator it = lst1.begin(); it != lst1.end(); it++)cout << *it << " ";cout << endl;cout << "删除相邻重复元素后:" << endl;lst1.unique();                         //删除相邻重复元素for (list<int>::iterator it = lst1.begin(); it != lst1.end(); it++)cout << *it << " ";cout << endl;system("pause");return 0;}

    运行后,打印输出:

    C++常见容器如何使用

    特别注意,由于list的底层是双向链表,因此insert操作无法直接像向量和双端队列一样直接插入数据,只能通过迭代器的自加移动到相应位置,再插入数据。

    2.4 array(数组)

    array和C语言中的数组没有太大的区别,建立后只能存储一种类型的数据,且不能改变大小。比较简单,举个例子:

    #include <iostream> #include <string>#include <array>using namespace std;// 程序的主函数int main(){array<int, 4> arr = {1, 3, 2};cout << "arr values:" << std::endl;for (array<int, 4>::iterator it = arr.begin(); it != arr.end(); it++) {cout << *it << " ";}cout << endl;cout << "sizeof(arr) = " << sizeof(arr) << endl;cout << "size of arr = " << arr.size() << endl;cout << "max size arr = " << arr.max_size() << endl;cout << "empty = " << (arr.empty() ? "no" : "yes") << endl;system("pause");return 0;}

    当然,最常见的,array也支持嵌套,可以采用这样的方式来构建二维(多维)数组,由于比较简单,就不举例了。

    2.5 string(字符串)

    与vector相似的容器。专门用于保存字符。随机访问快。尾部插入删除快。在部分说法中,string不算是STL容器,但是为了内容的完整性,我们还是将其一并学习。

    #include <iostream> #include <string>using namespace std;// 程序的主函数int main(){string s1 = "Bob:";string s2("hellow world!");for (int i = 0; i < s1.size(); i++){cout << s1[i];}cout << endl;for (int i = 0; i < s2.size(); i++){cout << s2[i];}cout << endl;cout << s1 + s2 << endl;s1.insert(s1.size(),"you say ");cout << s1 + s2 << endl;system("pause");return 0;}

    运行,打印输出如下:

    C++常见容器如何使用

    通过以上例子可以发现,与我们在C语言中学习的string并没有多少区别,其实本身区别也不是很大,只是在创建了之后还可以添加元素(盲猜是新创建了一个同名的string,仅此而已),且添加元素的方式也很简单,直接通过insert(插入位置,需要添加的字符串)这样的格式添加即可。上面一个例子是从末尾添加的,所以索引肯定是s1.size()。当然还有字符串的相加,字符串的比较等,都是属于更为基础的内容,没有添加到例子当中去,感兴趣的同学可以自己找资料去学习。

    2.6 map(映射)

    map容器和python中的字典非常类似,或者说一模一样。都是通过键值对的方式来存储和访问数据的,底层是通过红黑树来实现的。先来看个map的创建以及初始化的例子。

    #include <iostream> #include <map> #include <string>using namespace std;// 程序的主函数int main(){//map的创建和初始化//第一种:用insert函数插入pair数据:map<int, string> my_map;my_map.insert(pair<int, string>(1, "first"));my_map.insert(pair<int, string>(2, "second"));//第二种:用insert函数插入value_type数据:my_map.insert(map<int, string>::value_type(3, "first"));my_map.insert(map<int, string>::value_type(4, "second"));//第三种:用数组的方式直接赋值:my_map[5] = "first";my_map[6] = "second";map<int, string>::iterator it;           //迭代器遍历for (it = my_map.begin(); it != my_map.end(); it++)cout << it->first << "->" <<it->second << endl;system("pause");return 0;}

    运行,打印输出如下结果:

    C++常见容器如何使用

    从以上结果可以看出,其中数组直接赋值的方法最简单直接,最容易理解。当然map保存的是键值对,所以前面的int类型数据(key)并不代表其位置。比方说,我们将其中的int修改为float也是可以的。代码如下:

    #include <iostream> #include <map> #include <string>using namespace std;// 程序的主函数int main(){//map的创建和初始化//第一种:用insert函数插入pair数据:map<float, string> my_map;my_map.insert(pair<float, string>(1, "first"));my_map.insert(pair<float, string>(2, "second"));//第二种:用insert函数插入value_type数据:my_map.insert(map<float, string>::value_type(3, "first"));my_map.insert(map<float, string>::value_type(4, "second"));//第三种:用数组的方式直接赋值:my_map[5.3] = "first";my_map[6.6] = "second";map<float, string>::iterator it;           //迭代器遍历for (it = my_map.begin(); it != my_map.end(); it++)cout << it->first << "->" <<it->second << endl;system("pause");return 0;}

    当然,同其他的容器类型一样,map同样支持嵌套,比如:

    #include <iostream> #include <map> #include <string>using namespace std;// 程序的主函数int main(){//map的嵌套用法map<int,map<int,string>> my_map;my_map[1][1] = "张三";my_map[1][2] = "李四";my_map[1][3] = "王五";for (map<int, map<int, string>>::iterator it = my_map.begin(); it != my_map.end(); it++){for (map<int, string>::iterator in_it = it->second.begin(); in_it != it->second.end(); in_it++){cout << it->first << "年级" << in_it->first << "号同学:" << in_it->second << endl;}}cout << endl;system("pause");return 0;}

    运行,打印输出如下:

    C++常见容器如何使用

    还有一个很重要的问题,就是map元素的删除。map元素的删除有好多种方法,下面仅仅列举 常见几种。

    #include <iostream>#include <map>#include <string>using namespace std;void printMap(const map<string, int>& students){for (auto ii = students.begin(); ii != students.end(); ii++){cout << "姓名:" << ii->first<< " \t诗作: " << ii->second << "篇"<< endl;}cout << endl;}int main(int argc, char* argv[]) {map<string, int> students;students["李白"] = 346;students["杜甫"] = 300;students["王维"] = 200;students["李商隐"] = 113;students["杜牧"] = 156;cout << "原map:" << endl;printMap(students);students.erase("李白");cout << "删除 李白 后:" << endl;printMap(students);students.erase(std::begin(students));cout << "删除第一个元素后:" << endl;printMap(students);map<string, int>::iterator iter = students.find("杜牧");students.erase(iter);cout << "删除杜牧后:" << endl;printMap(students);system("pause");return 0;}

    运行后,打印输出:

    C++常见容器如何使用

    从上面的例子也可以看出,map中的键值对不一定是按照我们创建的顺序保存数据,map会按照key的值内部进行排序,但是保持其键值对的对应关系不变。

    2.7 set(集合)

    set也是一种关联性容器,它同map一样,底层使用红黑树实现,插入删除操作时仅仅移动指针即可,不涉及内存的移动和拷贝,所以效率比较高。从中文名就可以明显地看出,在set中不会存在重复的元素,若是保存相同的元素,将直接视为无效,我们先来看个简单的例子(关于set的创建和元素的添加等):

    #include <iostream> #include <set> #include <vector> using namespace std;// 程序的主函数int main(){vector<int> ivec;for (vector<int>::size_type i = 0; i != 10; i++) {ivec.push_back(i);ivec.push_back(i);}set<int> iset(ivec.begin(), ivec.end());cout << "向量中的元素为:" << endl;for (vector<int>::iterator it = ivec.begin(); it != ivec.end(); it++){cout << *it << " ";}cout << endl;cout << "集合中的元素为:" << endl;for (set<int>::iterator it = iset.begin(); it != iset.end(); it++){cout << *it << " ";}cout << endl;cout << "向量的大小为:" << endl;cout << ivec.size() << endl;cout << "集合的大小为:" << endl;cout << iset.size() << endl; system("pause");return 0;}

    打印输出:

    C++常见容器如何使用

    上面例子的方法,相当于直接将向量的值赋给了集合,从而顺便创建了集合,那么如果想通过逐一赋值的方式创建集合,又该如何编写代码呢?如何清除集合中的元素呢?以及是否知道某元素在集合中呢?同样我们通过一段代码来看一下。

    #include <iostream> #include <set> #include <vector> #include <string>using namespace std;// 程序的主函数int main(){set<string> set1;set1.insert("the"); //删除集合while (!set1.empty()){//获取头部set<string>::iterator it = set1.begin();//打印头部元素cout << *it << endl;//从头部删除元素set1.erase(set1.begin());}set<int>set2;for (int i = 100; i < 110; i++)set2.insert(i);cout << "set2中5出现的次数为:";cout << set2.count(5) << endl;set2.clear();cout << "set2清除之后的大小为:";cout << set2.size() << endl;system("pause");return 0;}

    运行,打印输出:

    C++常见容器如何使用

    通过以上的例子可以发现,set可以直接通过insert()方法添加数据,而数据内部是自动排序的,所以不用担心数据的顺序问题,当然也可以像map那样,通过迭代器添加到指定位置,查询set中有无该数据可以直接使用count()方法,有则返回1,无则返回0

    读到这里,这篇“C++常见容器如何使用”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    C++常见容器如何使用

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    C++常见容器如何使用

    本文小编为大家详细介绍“C++常见容器如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++常见容器如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.概述C++容器属于STL(标准模板库)中的一部
    2023-07-05

    C++中常见容器类如何使用

    本篇内容主要讲解“C++中常见容器类如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++中常见容器类如何使用”吧!综合示例1. vector:动态数组,支持随机访问#include
    2023-07-05

    C++中常见的容器使用问题及修复方案

    C++中常见的容器使用问题及修复方案引言:在C++中,容器是一种非常重要的数据结构,用于存储和管理数据。STL(Standard Template Library)提供了许多容器类型,如vector、list、map等,它们可以极大地简化程
    2023-10-22

    C++中常见的容器使用问题的解决方案

    C++中常见的容器使用问题的解决方案引言:C++作为一种广泛应用的编程语言,提供了丰富的容器类,如vector、list、map等,用于存储和操作数据。然而,容器的使用也常常伴随着一些问题,例如迭代器失效、内存泄漏等。本文将针对这些常见的容
    2023-10-22

    C++容器Vector如何使用

    今天小编给大家分享一下C++容器Vector如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Vector简介Vecto
    2023-06-30

    Qt常用容器类如何使用

    这篇文章主要介绍“Qt常用容器类如何使用”,在日常操作中,相信很多人在Qt常用容器类如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Qt常用容器类如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
    2023-07-02

    C++中queue容器如何使用

    这篇“C++中queue容器如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++中queue容器如何使用”文章吧。q
    2023-07-05

    C++如何使用std::vector容器

    这篇文章给大家分享的是有关C++如何使用std::vector容器的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言vector实质是C++的一个类,与数组很相似,但是vector的优势是可以动态扩展,不需要考虑
    2023-06-20

    C++中如何使用deque容器

    这篇文章主要介绍了C++中如何使用deque容器,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 deque 是 double-ended queue 的缩写,又称双端队列容器
    2023-06-15

    C++之list容器如何使用

    今天小编给大家分享一下C++之list容器如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、list底层结构list
    2023-07-05

    C++中的stack容器如何使用

    这篇文章主要讲解了“C++中的stack容器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++中的stack容器如何使用”吧!stack容器1 简介① stack是一种先进后出的容
    2023-07-05

    C++中的map容器如何使用

    这篇“C++中的map容器如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++中的map容器如何使用”文章吧。一、m
    2023-07-05

    一篇文章彻底搞懂C++常见容器

    容器就是一些特定类型对象的集合,容器可以分为顺序容器和关联容器,下面这篇文章主要给大家介绍了关于C++常见容器的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-02-13

    java常见log日志如何使用

    今天小编给大家分享一下java常见log日志如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前言log日志可以debu
    2023-07-02

    如何在C++中使用 STL 顺序容器

    今天就跟大家聊聊有关如何在C++中使用 STL 顺序容器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C++ 标准模板库 STL 顺序容器容器数据结构顺序性重复性支持迭代器vecto
    2023-06-15

    Python分支语句常见如何使用

    这篇文章主要介绍“Python分支语句常见如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python分支语句常见如何使用”文章能帮助大家解决问题。一、单分支语句:if语句单分支结构是最简单的
    2023-07-02

    C++常见的stl容器与相关操作示例解析

    所谓容器,就是可以承载,包含元素的一个器件,它是STL六大组件之一,是容器、算法、迭代器中最重要也是最核心的一部分
    2022-11-13

    C语言常见关键字怎么使用

    这篇文章主要介绍“C语言常见关键字怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C语言常见关键字怎么使用”文章能帮助大家解决问题。1、关键字关键字是C语言提供的,不能自己创建关键字;关键字不
    2023-07-02

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录