List(双向链表)
List是一种双向链表结构,可以从第一个元素开始删除、插入,也可以从最后一个元素删除、插入,下面介绍一下 List 中常用的几个函数;
一、List 中的 begin 和 end 函数 ;
和其他几种数据结构差不多,都是用来从第一个元素,访问到最后一个元素,返回的是当前指针;
list<int> L ;
*(L.begin()) // 输出第一个元素
*(L.end()) // 输出最后一个元素的下一个元素
二、List 中的 rbegin 和 rend 函数
也和其他几种数据结构差不多,从最后一个元素访问到第一个元素; 返回值如果需要存入一个变量中,这个变量应该这样定义
list<int>::reverse_iterator iter ;
list<int> L ;
iter = L.rbegin() ;
*iter // 输出最后一个元素
iter = L.rend() ;
*iter // 输出第一个元素前面的一个元素
三、List 中的 empty 函数
list<int> L ;
L.empty() ; // 如果链表为空则返回 true ,否则返回 false ;
四、List 中的 size 函数
list<int> L(5 , 10) ;
L.size() ; // 返回链表中元素的个数
五、List 中的 front 和 back 函数
list<int> L(5,10) ;
L.front() ; // 返回第一个元素
L.back() ; // 返回最后一个元素
六、List 中的 assign 函数
assign 函数用来对链表对象的重新分配 ;
list<int> L1 ;
list<int> L2 ;
L1.assign(5,10) ; // 向链表中添加 5 个元素 10 ;
L1.assign(5,11) ; // 把原来的 5 个元素 10 改为 11 ;
L2.assign( L1.begin() , L1.end() ) ; 将L1中的元素复制给L2 ;
int a[] = {1,2,3,4,5} ;
L2.assign(a,a+5) ; // 把数组 a 中的数据复制到 L2 中 ;
七、List 中的 push_front、push_back、pop_front、pop_back 函数
这几个函数就是双向链表的特殊之处,可以从头插入、删除,也可以从尾部插入和删除
list<int> L(5,10) ;
L.push_back(5) ; // 从最后插入一个元素 5 ;
L.pop_back() ; // 删掉最后一个元素
L.push_front(5) ; //在第一个元素前面插入一个元素 5 ;
L.pop_front() ; // 将第一个元素删除掉
八、List 中的 insert 函数
insert 函数中的参数可以有两个,也可以由三个,当参数有两个时,第一个代表在某个元素的前面,第二个参数代表要插入的数值;
当参数有三个时,第一个代表在某个元素之前插入,第二个元素和第三个元素代表要插入的范围;
list<int> L(5,10) ;
L.insert(L.begin(),5) ; //在第一个元素前插入一个元素 5 ;
L.insert(L.begin(),5,2) ; // 在第一个元素前插入 5 个元素 2 ;
int a[] = {8,2,3,4,5} ;
L.insert(L.begin(),a,a+5) ; // 将数组 a 插入到第一个元素之前 ;
九、List 中的 erase 函数
erase 用来删除链表中的数据元素
list<int> L(5,10) ;
L.erase(L.begin()) ; //删除链表中的第一个元素
L.erase( L.begin() , L.end() ) // 删除链表中的所有元素,相当于 L.assign(0) ;
十、List 中的 resize 函数
resize 和 其他数据结构一样,重新分配链表的大小 ;
list<int> L(5,10) ;
L.resize(3) ; // 将链表中原来的 5 个元素,缩短为现在的 3 个元素 ;
L.resize(8) ; // 将链表中原来的 3 个元素,扩大为现在的 8 个元素,扩大部分默认赋初值为 0 ;
L.resize(10,2) ; // 将链表中原来的 8 个元素,扩大为现在的 10 个元素,扩大部分赋值为 2 ;
十一、List 中的 clear 函数
list<int> L(5,10) ;
L.clear() ; // 清空链表中的所有元素, 相当于L.assign(0) , 还相当于L.erase(L.begin() , L.end()) ;
List(双向链表)的更多相关文章
- 学习Redis你必须了解的数据结构——双向链表(JavaScript实现)
本文版权归博客园和作者吴双本人共同所有,转载和爬虫请注明原文链接 http://www.cnblogs.com/tdws/ 下午分享了JavaScript实现单向链表,晚上就来补充下双向链表吧.对链表 ...
- 双向链表、双向循环链表的JS实现
关于链表简介.单链表.单向循环链表.JS中的使用以及扩充方法: 单链表.循环链表的JS实现 关于四种链表的完整封装: https://github.com/zhuwq585/Data-Structu ...
- 剑指Offer面试题:25.二叉搜索树与双向链表
一.题目:二叉搜索树与双向链表 题目:输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向.比如输入下图中左边的二叉搜索树,则输出转换之后的 ...
- Linux 内核数据结构:Linux 双向链表
Linux 内核提供一套双向链表的实现,你可以在 include/linux/list.h 中找到.我们以双向链表着手开始介绍 Linux 内核中的数据结构 ,因为这个是在 Linux 内核中使用最为 ...
- Linux 内核数据结构:双向链表
Linux 内核提供一套双向链表的实现,你可以在 include/linux/list.h 中找到.我们以双向链表着手开始介绍 Linux 内核中的数据结构 ,因为这个是在 Linux 内核中使用最为 ...
- 线性表-双向链表(LinkedList)
双向链表:如图1-3 所示,会把当前header拆分开,重新插入一个Entry<E>. LinkedList源码 0.首先这个类中的两个变量 private transient Entry ...
- Shuffling Machine和双向链表
1. 双向链表 https://github.com/BodhiXing/Data_Structure 2. Shuffling Machine https://pta.patest.cn/pta/t ...
- MS - 1 - 把二元查找树转变成排序的双向链表
## 1. 把二元查找树转变成排序的双向链表 ## ### 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表. ### 要求不能创建任何新的结点,只调整指针的指向. 10 ...
- javascript中的链表结构—双向链表
1.概念 上一个文章里我们已经了解到链表结构,链表的特点是长度不固定,不用担心插入新元素的时候新增位置的问题.插入一个元素的时候,只要找到插入点就可以了,不需要整体移动整个结构. 这里我们了解一下双向 ...
- Java自己实现双向链表LinkList
/** * <p> * Node 双向链表实体类 * <p> * * @author <a href="mailto:yangkj@corp.21cn.com& ...
随机推荐
- poj2136---输出特殊图形
#include <stdio.h> #include <stdlib.h> #include<string.h> ]; int find(int pos,int ...
- new Date().getTime()
new Date().getTime()获取当前时间戳; 不知道是毫秒级还是千分之一毫秒级别
- Android学习路线(六)为Android应用加入ActionBar
Action bar 是你可以为你的应用的Activity实现的最为重要的设计元素之中的一个.它提供了集中UI特性.而且通过提供和其它的Android应用的一致性体验让你的应用可以非常快被用户熟悉.基 ...
- HDU 4914 Linear recursive sequence(矩阵乘法递推的优化)
题解见X姐的论文 矩阵乘法递推的优化.仅仅是mark一下. .
- golang之interface(接口)与 reflect 机制
一.概述 什么是interface,简单的说,interface是一组method的组合,通过interface来定义对象的一组行为: interface类型定义了一组方法,如果某个对象实现了某个接口 ...
- SQL学习之高级数据过滤
一.高级数据过滤之IN操作符 IN 操作符用来指定条件范围,范围中的每个条件都可以进行匹配.IN取一组由逗号分隔.括在圆括号中的合法值.代码如下: select ItemId,ItemName,Che ...
- Css 外边距折叠(collapsed margin ) 浅析
Css 外边距折叠(collapses margin ) a.先来看看w3c 文档对于外边距折叠的定义: In CSS, the adjoining margins of two or more bo ...
- button变成href (即按钮超链效果)
法一: 这种方法适合做单纯的HTML静态页面,因为它只有button的显示效果,但不能真的跳转.貌似是鸡肋,没多大用. 法二: 1.新打开一个页面 2.本页打开 在超链中实现打开新页面用targe ...
- 交换机access和trunk的一些小结(转)
以太网端口有 3种链路类型:access.trunk.hybird Access类型端口只能属于1个VLAN 般用于连接计算机 端口: Trunk类型端口可以允许多个VLAN通过,可以接收和发送多个 ...
- Javascript类型检测
原地址 http://www.cnblogs.com/fool/archive/2010/10/07/javascrpt.html 开门见山,我们先来看一下代码: var is = function ...