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. spring data jpa 简单使用

    通过解析方法名创建查询 通过前面的例子,读者基本上对解析方法名创建查询的方式有了一个大致的了解,这也是 Spring Data JPA 吸引开发者的一个很重要的因素.该功能其实并非 Spring Da ...

  2. swift 基础-1

    一.常量与变量 var testVariable = 42         testVariable = 50         println(testVariable)                ...

  3. JS将人民币小写金额转换为大写

    /** 数字金额大写转换(可以处理整数,小数,负数) */ function smalltoBIG(n) { var fraction = ['角', '分']; var digit = ['零', ...

  4. 电话号码 马赛克*号 string类扩展

    /// <summary> /// 字符串马赛克 /// </summary> /// <param name="source"></pa ...

  5. RSA加密解密(转)

    RSA加密解密 对于RSA产生的公钥.私钥,我们可以有两种方式可以对信息进行加密解密.私钥加密-公钥解密 和 公钥加密-私钥解密RSA公钥加密算法是1977年由罗纳德·李维斯特(Ron Rivest) ...

  6. 清理winsxs文件夹(系统更新文件)的第三方工具

    工具名称(第三方): Windows Update Clean Tool 下载地址: http://www.xiazaiba.com/html/24145.html http://dx5.xiazai ...

  7. BZOJ 4896 :[Thu Summer Camp2016]补退选 Trie树+Vector

    4896: [Thu Summer Camp2016]补退选 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 315  Solved: 97[Submi ...

  8. java.lang.ClassCastException: com.ch.hibernate.Student_$$_javassist_0 cannot be cast to javassist.util.proxy.Proxy

    利用query动态查询时,报错 java.lang.ClassCastException: com.ch.hibernate.Student_$$_javassist_0 cannot be cast ...

  9. GWT module 'xxx' may need to be (re)compiled解决办法

    使用GWT Eclipse Plug-in开发GWT应用,启动程序,在浏览器地址栏中输入http://127.0.0.1:8888/HelloWorld.html,没有出现我所期望的结果,而是弹出如下 ...

  10. nodejs安装遇到npm命令无法使用问题

    解决方法: 在用户文件夹中建立npm文件夹就可以使用了. 再使用npm命令就可以了.