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()) ;

最新文章

  1. Canvas绘图中的路径描边与填充
  2. Oracle Recommended Patches -- &quot;Oracle JavaVM Component Database PSU&quot; (OJVM PSU) Patches (文档 ID 1929745.1)
  3. 【初窥javascript奥秘之事件机制】论“点透”与“鬼点击”
  4. Android简单自定义圆形和水平ProgressBar
  5. ESB 中的流量控制
  6. 新建jsp报错“The superclass &quot;javax.servlet.http.HttpServlet&quot; was not found on the Java Build Path”
  7. .net 4.0 运行时中运行.net2.0开发的程序
  8. form表单普通提交预览显示,读取显示tmp文件
  9. 单页应用Scrat实践
  10. Code Forces 448C Painting Fence 贪婪的递归
  11. 无限“递归”的python程序
  12. python3全栈开发- 元类metaclass(面试必考题)
  13. goroutine的意义与实现
  14. iPhone 尺寸 iPhonex
  15. linux第八周
  16. 286 walls and gate最近的出口
  17. leetcode-896-单调数列
  18. rrdtool ubuntu python snmpwalk
  19. sql 2012先分离迁移mdf mlf 文件到别的机器后附加 数据库成只读的修复方法
  20. 如何实现字符串的翻转,不用php库函数翻转字符串

热门文章

  1. 二道shell面试题
  2. openstack 的 policy 问题。
  3. collection系列用法-defaultdict()
  4. 使用border-image实现类似iOS7的1px底边
  5. Choosing Between ElasticSearch, MongoDB &amp;amp; Hadoop
  6. 【翻译】在Ext JS 5种使用ViewControllers
  7. Android中进行流量统计
  8. 尝试解决IIS问题一些方法
  9. VBA 简单调试
  10. Unity StrangeIoc框架 (三)signal信号方式