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; ...
随机推荐
- form-data、x-www-form-urlencoded、raw、binary的区别
1.form-data: 就是http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开.既可以上传键值对,也可以上传文件.当上传的字段是文件时 ...
- 关于纠正《Hive权威指南》中的结论~“hive在使用set自定义变量时,hivevar命名空间是可选的”~的论证
背景: 根据<Hive权威指南>上讲,在hive-0.8.0以后可以使用--define key=value命令定义用户自定义的变量以便在Hive脚本中引用.当用户使用这个功能时,Hive ...
- pc端常见布局---垂直居中布局 单元素定高
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Unity中实现全局管理类的几种方式
(搬运自我在SegmentFault的博客) 如何在Unity中实现全局管理类?由于Unity脚本的运行机制和面向组件编程(COP)的思想,实现起来和普通的方式略有差别. 第一种方式是使用静态类.适合 ...
- MVC的验证码
后台: /// <summary> /// 创建验证码的图片 /// </summary> /// <param name="validateCode" ...
- 《毛毛虫团队》第九次团队作业:BETA冲刺与团队项目验收
一:实验名称:Beta冲刺与验收准备 二:实验目的与要求 (1)掌握软件黑盒测试技术: (2)学会编制软件项目总结PPT.项目验收报告: (3)掌握软件项目验收内容,验收流程. 三.实验内容与步骤 任 ...
- Spring多种方式实现依赖注入
平常的Java开发中,程序员在某个类中需要依赖其它类的方法. 通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理. Spring提出了依赖注入的思想,即依赖类不由 ...
- Java Object类 instanceof关键字 练习:判断是否为同一人 集合按照人的年龄排序,如果年龄相同按名字的字母顺序升序 Comparator比较器
package com.swift; public class Same_Person_Test { public static void main(String[] args) { /* * Obj ...
- Java基础操作面试题:Map集合排序 需要TreeMap 构造方法参数有比较器 输入字符串,统计A、B、C、D、出现次数,由高到低输出字母和出现次数,使用Map集合完成此题
Map和Collections是同级别的,不能像List排序那样直接用Collections.sort(new Comparator<?>(){ 复写compara方法}); HashMa ...
- Java第7次作业:造人类(用private封装,用static关键字自己造重载输出方法)什么是面向对象程序设计?什么是类和对象?什么是无参有参构造方法 ?什么是封装?
什么是面向对象程序设计? 我们称为OOP(Object Oriented Programming) 就是非结构化的程序设计 要使用类和对象的方法来进行编程 什么是类,什么是对象 类就是封装了属性和 ...