C++ list-map链表与映射表的简单使用

 更新时间:2023年05月05日 11:16:59   作者:程序员懒羊羊  
本文主要介绍了C++ list-map链表与映射表的简单使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

list 链表

链表是由节点之间通过指针连接而成的链式结构存储结构体,对于链表,C++标准库中已经提供了封装好的链表了。

require:

#include <list>  //1.包含头文件
using namespace std;  //2.打开标准命名空间

定义链表,并在首、尾添加、删除元素

list<int> lst;  //定义链表对象,list后<>中指定节点元素类型
lst.push_front(0);  //链表头添加
lst.push_back(1);   //链表尾添加
lst.pop_front();  //删除头节点
lst.pop_back();   //删除尾节点

迭代器遍历链表

//begin() : 返回头节点
//end()   : 返回无效的尾节点
list<int>::iterator ite = lst.begin();  //定义迭代器指向头节点
while(ite != lst.end()) {   //不等于链表的尾节点
    cout << *ite << "  ";   //operator*
    ite++;                  //operator++
}

任意位置插入或删除

//insert()  erase()
ite2 = lst.insert(ite1, value);  //在 ite1 指向的位置之前插入元素value,返回插入元素的迭代器
ite2 = lst.erase(ite1);  //删除 ite1 指向的节点,ite1 将失效不可用,返回删除节点的下一个节点
ite = lst.erase(ite);  //多数情况下,用于删除的迭代器也可以承接其返回值,自带++效果
lst.erase(ite++);  //上述情况也可以这么写

获取首尾节点中元素的值

注意:end() 返回的是无效的尾节点,不能对其进行间接引用

lst.front();  //*lst.begin();
lst.back();   //*(--lst.end());

使用增强的范围for循环进行遍历链表

for (int v : lst) {
    cout << v << "  ";
}

加引用可以修改节点里的值

for (int &v : lst) {
    //...
    v=value;
    //...
}

其他常见的函数

lst.empty();  //判断当前链表是否为空(bool类型),空返回true,非空返回false
lst.size();   //获取链表的长度(有效节点数量)
lst.clear();  //清空链表,empty 为 ture,size 为 0

map 映射表

map 为映射表,每一个元素称之为键值对(pair),分为键值(key)和实值(value),键值是唯一的(不能重复),所有元素都会根据元素的键值自动被排序。

require:

#include <map>  //1.包含头文件
using namespace std;  //2.打开标准命名空间

定义map

//格式:map<key,value> mm;
map<char, int> mm;

添加

//格式:mm[key] = value;
mm['B'] = 1;  //使用[]添加元素
mm['D'] = 2;
mm['A'] = 3;
mm['C'] = 4;

使用函数插入元素

mm.insert(pair<char, int>('E', 5));

迭代器遍历map

map中的元素会自动按照键值进行排序

    map<char, int>::iterator ite = mm.begin();
    while (ite != mm.end()) {
        //first : 取键值,后面不要加(),second : 实值
        cout << ite->first << "-" << ite->second << "   ";
            ite++;
    }
    cout << endl;

修改

当键值已经存在时,会直接修改实值

mm['B'] = 50;  //如果键值存在,则是通过键值修改实值

删除

例:删除第二个元素

    ite = ++mm.begin();
    ite = mm.erase(ite);  //删除 , 参数迭代器默认会失效,所以一般情况下返回值会接一下,返回的是删除的下一个

使用增强的范围for循环遍历

    for (pair<char,int> pr : mm) {
        cout << pr.first << "-" << pr.second << "  ";
    }
    cout << endl;

使用引用,也可以修改实值

count统计

统计某个键值出现的次数,map键值唯一,可以用来判断某个键值是否存在

    int count = mm.count('B');  //按照键值统计,可用于判断键值是否存在
    cout << count << endl;

到此这篇关于C++ list-map链表与映射表的简单使用的文章就介绍到这了,更多相关C++ list-map链表与映射表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++中std::vector的具体使用

    C++中std::vector的具体使用

    C++标准库中的std::vector是一种动态数组容器,适用于算法竞赛中的动态数据存储、数组扩展和模拟栈/二维数组等场景,本文就来介绍一下,感兴趣的可以了解一下
    2025-02-02
  • C++编程之 std::forward使用例子

    C++编程之 std::forward使用例子

    std::forward 是一个 C++11 中的模板函数,其主要作用是在模板函数或模板类中,将一个参数以“原样”(forward)的方式转发给另一个函数,这篇文章主要介绍了C++编程之 std::forward,需要的朋友可以参考下
    2023-03-03
  • C++中的for-each循环使用

    C++中的for-each循环使用

    范围循环是C++11引入的特性,用于简化数组和容器的遍历过程,它通过直接操作元素而不是使用索引或迭代器,范围循环可以使用引用或const修饰符来控制元素的修改权限,适用于所有支持begin()和end()方法的容器,该循环方式不适用于未提供这些方法的C++98/03容器
    2024-09-09
  • 详解DAG上的DP

    详解DAG上的DP

    DAG:有向无环图。DAG是学习动态规划的基础,很多问题都可以直接转化为DAG上的最长路、最短路或路径计数问题。本文将详细介绍DAG上的DP。
    2021-05-05
  • 一文详解C++的访问说明符

    一文详解C++的访问说明符

    访问说明符是 C++ 中控制类成员(属性和方法)可访问性的关键字,它们用于封装类数据并保护其免受意外修改或滥用,本文将给大家详细的介绍一下C++的访问说明符,感兴趣的朋友可以参考下
    2024-04-04
  • C++实现统计代码运行时间计时器的简单实例

    C++实现统计代码运行时间计时器的简单实例

    这篇文章主要介绍了 C++实现统计代码运行时间计时器的简单实例的相关资料,需要的朋友可以参考下
    2017-07-07
  • C++解决合并两个排序的链表问题

    C++解决合并两个排序的链表问题

    本文主要介绍了通过C++解决合并两个排序的链表并使新链表中的节点仍然是递增排序的。文中代码讲解详细,有需要的朋友可以参考一下
    2021-12-12
  • 深入C/C++浮点数在内存中的存储方式详解

    深入C/C++浮点数在内存中的存储方式详解

    本篇文章是对C/C++浮点数在内存中的存储方式进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C语言三子棋游戏实现代码解析

    C语言三子棋游戏实现代码解析

    这篇文章主要为大家详细介绍了C语言三子棋游戏实现代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • C语言数据结构之双链表&循环链表&静态链表详解

    C语言数据结构之双链表&循环链表&静态链表详解

    这篇文章主要为大家详细介绍了C语言数据结构中双链表&循环链表&静态链表的原理与使用,文中的示例代码讲解详细,感兴趣的可以了解一下
    2022-09-09

最新评论