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(双向链表)的更多相关文章

  1. 学习Redis你必须了解的数据结构——双向链表(JavaScript实现)

    本文版权归博客园和作者吴双本人共同所有,转载和爬虫请注明原文链接 http://www.cnblogs.com/tdws/ 下午分享了JavaScript实现单向链表,晚上就来补充下双向链表吧.对链表 ...

  2. 双向链表、双向循环链表的JS实现

    关于链表简介.单链表.单向循环链表.JS中的使用以及扩充方法:  单链表.循环链表的JS实现 关于四种链表的完整封装: https://github.com/zhuwq585/Data-Structu ...

  3. 剑指Offer面试题:25.二叉搜索树与双向链表

    一.题目:二叉搜索树与双向链表 题目:输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向.比如输入下图中左边的二叉搜索树,则输出转换之后的 ...

  4. Linux 内核数据结构:Linux 双向链表

    Linux 内核提供一套双向链表的实现,你可以在 include/linux/list.h 中找到.我们以双向链表着手开始介绍 Linux 内核中的数据结构 ,因为这个是在 Linux 内核中使用最为 ...

  5. Linux 内核数据结构:双向链表

    Linux 内核提供一套双向链表的实现,你可以在 include/linux/list.h 中找到.我们以双向链表着手开始介绍 Linux 内核中的数据结构 ,因为这个是在 Linux 内核中使用最为 ...

  6. 线性表-双向链表(LinkedList)

    双向链表:如图1-3 所示,会把当前header拆分开,重新插入一个Entry<E>. LinkedList源码 0.首先这个类中的两个变量 private transient Entry ...

  7. Shuffling Machine和双向链表

    1. 双向链表 https://github.com/BodhiXing/Data_Structure 2. Shuffling Machine https://pta.patest.cn/pta/t ...

  8. MS - 1 - 把二元查找树转变成排序的双向链表

    ## 1. 把二元查找树转变成排序的双向链表 ## ### 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表. ### 要求不能创建任何新的结点,只调整指针的指向. 10       ...

  9. javascript中的链表结构—双向链表

    1.概念 上一个文章里我们已经了解到链表结构,链表的特点是长度不固定,不用担心插入新元素的时候新增位置的问题.插入一个元素的时候,只要找到插入点就可以了,不需要整体移动整个结构. 这里我们了解一下双向 ...

  10. Java自己实现双向链表LinkList

    /** * <p> * Node 双向链表实体类 * <p> * * @author <a href="mailto:yangkj@corp.21cn.com& ...

随机推荐

  1. HDU 5809 Ants(KD树+并查集)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5809 [题目大意] 给出一些蚂蚁和他们的巢穴,一开始他们会在自己的巢穴(以二维坐标形式给出),之后 ...

  2. uva 215 hdu 1455 uvalive5522 poj 1011 sticks

    //这题又折腾了两天 心好累 //poj.hdu数据极弱,找虐请上uvalive 题意:给出n个数,将其分为任意份,每份里的数字和为同一个值.求每份里数字和可能的最小值. 解法:dfs+剪枝 1.按降 ...

  3. javascript数组去重算法-----5

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 链表-Add Two Numbers

    第一版代码(很挫很罗嗦,不过是第一次做,记录一下成长的脚步!继续努力!) /*struct ListNode { int val; struct ListNode *next; };*/ typede ...

  5. JQuery 操作input

    获取选中的值 获取一组radio被选中项的值 var item = $('input[@name=items][@checked]').val(); 获取select被选中项的文本 var item ...

  6. 3.一步一步学c#(三):对象和类型

    类和结构 类和结构实际上都是创建对象的模板,每个对象都包含数据,并提供了处理和访问数据的方法,. 结构与类的区别是它们在内存中的存储方式,访问方式(类是存储在堆(heap)上的引用类型),而结构是存储 ...

  7. URL编码解码

    ios url 编码和解码 1.url编码 ios中http请求遇到汉字的时候或者像是%…@#¥%&*这些字符的时候也可以使用下面的方法,需要转化成UTF-8,用到的方法是: NSString ...

  8. NSURLSessionConfiguration的简单实用

    NSURLSessionConfiguration 基于前面学习了NSURLSession的知识,这边文章就讲下NSURLSessionConfiguration相关应用,(这名字可真长). 简而言之 ...

  9. C/C++中volatile关键字详解 (转)

    1. 为什么用volatile? C/C++ 中的 volatile 关键字和 const 对应,用来修饰变量,通常用于建立语言级别的 memory barrier.这是 BS 在 "The ...

  10. C++结构体中sizeof

    说明: 结构体的sizeof值,并不是简单的将其中各元素所占字节相加,而是要考虑到存储空间的字节对齐问题.这些问题在平时编程的时候也确实不怎么用到,但在一些笔试面试题目中出是常常出现,一.解释 现代计 ...