List --- 双向列表

  List是线性列表结构,数据查找需要一个接一个,不能直接得到元素地址,检索时间与目标元素的位置成正比。但是插入数据比较快,可以在任何位置插入数据或者删除数据。list特点是:

  (1) 不使用连续的内存空间这样可以随意地进行动态操作;

  (2)可以在内部任何位置快速地插入或删除,当然也可以在两端进行push和pop  。

  (3) 不能进行内部的随机访问,即不支持[ ]  操作符和vector.at()  ;

大多数函数和vector的类似,这里就不解释了,有几个不一样的如下:

  merge()  合并两个list  --- 链接之后会把第二个链表删除掉

    void merge( list &lst );//把自己和lst链表连接在一起
    void merge( list &lst, Comp compfunction ); //指定compfunction,则将指定函数作为比较的依据。

     list <int> listTest;
list <int>::iterator it;
list <int> listTest2;
// listTest.assign(4,66);//初始化,给4个元素赋值为66
for (int i=;i<;i++)
{
listTest.push_back(i);//
listTest2.push_back(+i);//
} listTest.merge(listTest2);
cout<<listTest.back()<<endl;//获取最后一个元素
//cout<<listTest2.back()<<endl;
if (listTest2.empty())
{
cout<<"listTest2 is ampty"<<endl;
}

  void remove( const TYPE &val ); //删除链表中所有值为val的元素

    void remove( const TYPE &val ); //删除链表中所有值为val的元素

     listTest.remove();//移除最后一个元素
cout<<listTest.back()<<endl;//获取最后一个元素

  unique()  删除list中重复的元素

    void unique();//删除链表中所有重复的元素
    void unique( BinPred pr );// 指定pr,则使用pr来判定是否删除。

     it = listTest.end();
cout<<listTest.size()<<endl;
cout<<listTest.back()<<endl;//获取最后一个元素
listTest.insert(it,);//插入到it以前
listTest.insert(it,);//插入到it以前
listTest.unique();//删除所有重复元素
cout<<"*******************"<<endl;
cout<<listTest.size()<<endl;
cout<<listTest.back()<<endl;//获取最后一个元素

  splice()  合并两个list   

    void splice( iterator pos, list &lst );//把lst连接到pos的位置
    void splice( iterator pos, list &lst, iterator del );//插入lst中del所指元素到现链表的pos上
    void splice( iterator pos, list &lst, iterator start, iterator end );//用start和end指定范围。

     it = listTest.end();
listTest.splice(it,listTest2);//将链表2链接到1后面
cout<<listTest.back();

  完整代码如下:

 #include "list"
#include "iostream"
using namespace std;
int main()
{
list <int> listTest;
list <int>::iterator it;
list <int> listTest2;
// listTest.assign(4,66);//初始化,给4个元素赋值为66
for (int i=;i<;i++)
{
listTest.push_back(i);
listTest2.push_back(+i);
} // listTest.merge(listTest2);
// cout<<listTest.back()<<endl;//获取最后一个元素
// //cout<<listTest2.back()<<endl;
// if (listTest2.empty())
// {
// cout<<"listTest2 is ampty"<<endl;
// }
// listTest.remove(19);//移除最后一个元素
// cout<<listTest.back()<<endl;//获取最后一个元素
//
it = listTest.end();
cout<<listTest.size()<<endl;
cout<<listTest.back()<<endl;//获取最后一个元素
listTest.insert(it,);
listTest.insert(it,);
listTest.unique();//删除所有重复元素
cout<<"*******************"<<endl;
cout<<listTest.size()<<endl;
cout<<listTest.back()<<endl;//获取最后一个元素
cout<<listTest.front()<<endl;//获取最后一个元素
if (listTest.empty())
{
cout<<"listTest is empty"<<endl;
} // it = listTest.end();
// listTest.splice(it,listTest2);//将链表2链接到1后面
// cout<<listTest.back();
getchar();
getchar();
return ;
}

Code

STL学习笔记2--list的更多相关文章

  1. Effective STL 学习笔记 39 ~ 41

    Effective STL 学习笔记 39 ~ 41 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  2. Effective STL 学习笔记 Item 38 : Design functor classes for pass-by-value

    Effective STL 学习笔记 Item 38 : Design functor classes for pass-by-value */--> div.org-src-container ...

  3. Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据

    Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据 */--> div.org-src-container { font-size: 85%; font-fam ...

  4. Effective STL 学习笔记 32 ~ 33

    Effective STL 学习笔记 32 ~ 33 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  5. Effective STL 学习笔记 31:排序算法

    Effective STL 学习笔记 31:排序算法 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  6. Effective STL 学习笔记 Item 30: 保证目标区间足够大

    Effective STL 学习笔记 Item 30: 保证目标区间足够大 */--> div.org-src-container { font-size: 85%; font-family: ...

  7. Effective STL 学习笔记 Item 26: Prefer Iterator to reverse_iterator and const_rever_itertor

    Effective STL 学习笔记 Item 26: Prefer Iterator to reverse_iterator and const_rever_itertor */--> div ...

  8. Effective STL 学习笔记: Item 22 ~ 24

    Effective STL 学习笔记: Item 22 ~ 24 */--> div.org-src-container { font-size: 85%; font-family: monos ...

  9. Effective STL 学习笔记 Item 21:Comparison Function 相关

    Effective STL 学习笔记 Item 21:Comparison Function 相关 */--> div.org-src-container { font-size: 85%; f ...

  10. Effective STL 学习笔记:19 ~ 20

    Effective STL 学习笔记:19 ~ 20 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

随机推荐

  1. form-data、x-www-form-urlencoded、raw、binary的区别

    1.form-data: 就是http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开.既可以上传键值对,也可以上传文件.当上传的字段是文件时 ...

  2. 关于纠正《Hive权威指南》中的结论~“hive在使用set自定义变量时,hivevar命名空间是可选的”~的论证

    背景: 根据<Hive权威指南>上讲,在hive-0.8.0以后可以使用--define key=value命令定义用户自定义的变量以便在Hive脚本中引用.当用户使用这个功能时,Hive ...

  3. pc端常见布局---垂直居中布局 单元素定高

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  4. Unity中实现全局管理类的几种方式

    (搬运自我在SegmentFault的博客) 如何在Unity中实现全局管理类?由于Unity脚本的运行机制和面向组件编程(COP)的思想,实现起来和普通的方式略有差别. 第一种方式是使用静态类.适合 ...

  5. MVC的验证码

    后台: /// <summary> /// 创建验证码的图片 /// </summary> /// <param name="validateCode" ...

  6. 《毛毛虫团队》第九次团队作业:BETA冲刺与团队项目验收

    一:实验名称:Beta冲刺与验收准备 二:实验目的与要求 (1)掌握软件黑盒测试技术: (2)学会编制软件项目总结PPT.项目验收报告: (3)掌握软件项目验收内容,验收流程. 三.实验内容与步骤 任 ...

  7. Spring多种方式实现依赖注入

    平常的Java开发中,程序员在某个类中需要依赖其它类的方法. 通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理. Spring提出了依赖注入的思想,即依赖类不由 ...

  8. Java Object类 instanceof关键字 练习:判断是否为同一人 集合按照人的年龄排序,如果年龄相同按名字的字母顺序升序 Comparator比较器

    package com.swift; public class Same_Person_Test { public static void main(String[] args) { /* * Obj ...

  9. Java基础操作面试题:Map集合排序 需要TreeMap 构造方法参数有比较器 输入字符串,统计A、B、C、D、出现次数,由高到低输出字母和出现次数,使用Map集合完成此题

    Map和Collections是同级别的,不能像List排序那样直接用Collections.sort(new Comparator<?>(){ 复写compara方法}); HashMa ...

  10. Java第7次作业:造人类(用private封装,用static关键字自己造重载输出方法)什么是面向对象程序设计?什么是类和对象?什么是无参有参构造方法 ?什么是封装?

    什么是面向对象程序设计? 我们称为OOP(Object  Oriented  Programming) 就是非结构化的程序设计 要使用类和对象的方法来进行编程 什么是类,什么是对象 类就是封装了属性和 ...