STL学习笔记2--list
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的更多相关文章
- Effective STL 学习笔记 39 ~ 41
Effective STL 学习笔记 39 ~ 41 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- 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 ...
- Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据
Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据 */--> div.org-src-container { font-size: 85%; font-fam ...
- Effective STL 学习笔记 32 ~ 33
Effective STL 学习笔记 32 ~ 33 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- Effective STL 学习笔记 31:排序算法
Effective STL 学习笔记 31:排序算法 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- Effective STL 学习笔记 Item 30: 保证目标区间足够大
Effective STL 学习笔记 Item 30: 保证目标区间足够大 */--> div.org-src-container { font-size: 85%; font-family: ...
- 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 ...
- Effective STL 学习笔记: Item 22 ~ 24
Effective STL 学习笔记: Item 22 ~ 24 */--> div.org-src-container { font-size: 85%; font-family: monos ...
- Effective STL 学习笔记 Item 21:Comparison Function 相关
Effective STL 学习笔记 Item 21:Comparison Function 相关 */--> div.org-src-container { font-size: 85%; f ...
- Effective STL 学习笔记:19 ~ 20
Effective STL 学习笔记:19 ~ 20 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
随机推荐
- Java并发(一):基础概念
对于Java并发,我也是属初学阶段,用的参考书是:"Java并发编程实战",写博时也参考了很多类似主题的博客,博主意在记录自己的学习路程,供网友讨论学习之用; 周末写的差不多了,今 ...
- Webpack 入门学习
1.什么是Webpack? Webpack可以看做是模块打包机:它做的事情是,分析你的项目结构,找到JavaScript模块以及其它的一些浏览器不能直接运行的拓展语言(Scss,TypeScript等 ...
- C++ error:Debug Assertion Failed.Expression:_BLOCK_TYPE_IS_VALID(phead->nBlock)
Debug Assertion Failed.Expression:_BLOCK_TYPE_IS_VALID(phead->nBlockUse) 关于上面这个错误,我在上一篇文章中的程序遇到过了 ...
- 【js类库Raphaël】使用raphael.js根据点坐标绘制平滑曲线
一.可供参考的文档资料. raphaeljs官网:http://raphaeljs.com/ w3c关于path的介绍:http://www.w3.org/TR/2003/REC-SVG11-200 ...
- [ros]编译ORBSLAM2时候,ros路径问题
CMake Error at CMakeLists.txt:2 (include): include could not find load file: /core/rosbuild/rosbuild ...
- NVM for Windows下载与安装
下载NVM for Windows https://github.com/coreybutler/nvm-windows/releases nvm-noinstall.zip: 这个是绿色免安装版本, ...
- 给广大码农分享福利:一个业界良心的github仓库,中文计算机资料
我今天查资料时无意发现的,https://github.com/CyC2018/CS-Notes 这个仓库包含了下列几个维度的计算机学习资料: 深受国内程序员喜爱,已经有超过3万多star了. 1. ...
- CodeForces 66C Petya and File System (实现)
模拟题,map搞一搞.要想清楚一个结点应该是要通过一个字符串找到下一个结点,题目保证所以文件夹非空,所以只要判断一个结点是不是叶子结点就可以判断它是不是文件,用了点c11的特性. #include&l ...
- QT 调试输出格式
Qt调试输出格式: 1,qDebug() << qPrintable(firstNode.nodeName()) << qPrintable(firstNode.nodeVal ...
- linux目录结构及文件管理
Linux的目录结构: / 根分区 linux文件系统的起点 /bin 普通用户的命令,普通用户能使用 /sbin 管理员使用的命令,只有管理 ...