[C++] list双向链表使用方法

目录

链表基本操作

定义类

双向链表有专门的头文件

cpp 复制代码
#include <list>
// 当然如果你用<bits/stdc++.h>的话就也无所谓了

忽然想到一件事情, 不会有人不知道bits/stdc++.h是什么吧?传送!

双向链表这样定义

cpp 复制代码
list<type> name;
// type: 链表每个元素的数据类型
// name: 链表名

// 下面是一个例子:
list<int> ls;		// 后面讲操作的时候就以ls为例

使用类

常规

增删改查都在下面:

cpp 复制代码
// 对链表开头操作
ls.push_front(x);	// 在ls开头添加x
ls.front();			// 返回ls开头元素
ls.pop_front();		// 删除ls开头元素

// 对链表末尾进行操作
ls.push_back(x);	// 在ls末尾添加x
ls.back();			// 返回ls末尾元素
ls.pop_back();		// 删除ls末尾元素

一些特殊的方法:

cpp 复制代码
ls.size();			// 返回ls的元素个数
ls.empty();			// 返回ls是否为空(空返回false, 否则true)
ls.clear();			// 清空ls

排序

cpp 复制代码
ls.sort();						// 升序
// 可以把一个函数当作参数传入, 传入则按照函数实现的排序规则来排序, 类似algorithm中的sort

ls.sort(greater</*type*/>()); 	// 降序
// type替换为ls对应的数据类型
// 如果不是在std命名空间中, 则需要使用以下方法
ls.sort(std::greater</*type*/>());

遍历

由于链表没有索引 , 我们使用迭代器(iterator)进行元素的访问 , 进而实现遍历的功能.

cpp 复制代码
ls.begin();		// 返回指向ls开头的迭代器
ls.end();		// 返回指向ls结尾的迭代器(最后一个元素的下一个位置)

这里比较难理解, 特别是end, 所以给大家配了一幅图

理解到这里后, 就可以开始讲遍历了:

cpp 复制代码
for(auto pos = ls.begin(); pos != ls.end(); pos++){
	// 元素使用*pos来访问
}

这里我们使用了C++11(或以上)特有auto, 如果版本较旧的话需要替换为list<type>::iterator, 把type替换为ls对应的数据类型.

如果你使用的是C++11(或以上), 推荐你使用一种更简便的方法:

cpp 复制代码
for(int num : ls){
	// 元素为num
}

这种方法有一个弊端, 就是不能局部遍历.

链表存储原理

相关推荐
橘颂TA11 分钟前
【剑斩OFFER】算法的暴力美学——leetCode 946 题:验证栈序列
c++·算法·leetcode·职场和发展·结构与算法
闻缺陷则喜何志丹13 分钟前
【状态机动态规划】3686. 稳定子序列的数量|1969
c++·算法·动态规划·力扣·状态机动态规划
liulilittle15 分钟前
OPENPPP2 网络驱动模式
开发语言·网络·c++·网络协议·信息与通信·通信
mjhcsp19 分钟前
C++ AC 自动机:原理、实现与应用全解析
java·开发语言·c++·ac 自动机
爱吃生蚝的于勒38 分钟前
【Linux】进程间通信之匿名管道
linux·运维·服务器·c语言·数据结构·c++·vim
wanderist.1 小时前
C++输入输出的一些问题
开发语言·c++·图论
金色熊族1 小时前
MV结构下设置Qt表格的代理(2)
c++·qt
Morwit1 小时前
Qt qml创建c++类的单例对象
开发语言·c++·qt
June`1 小时前
IO模型全解析:从阻塞到异步(高并发的reactor模型)
linux·服务器·网络·c++
YxVoyager1 小时前
Qt C++ :QRegularExpression 正则表达式使用详解
c++·qt·正则表达式