STL标准库-容器-forward_list
技术在于交流、沟通,本文为博主原创文章转载请注明出处并保持作品的完整性。
forward_list即单向list,功能少额外开销就小.而且只能在前段插入元素
结构如下

一 定义
#include <forward_list>
int main(int argc, const char * argv[]) {
//a.定义 list<typeName> name;
forward_list<int> l;
//b.拷贝构造
forward_list<int> l1(l);
//c.拷贝赋值
l1 = l;
//d.按指定元素个数定义 含五个默认值是0的元素的链表
forward_list<int> l2();
//e.指定元素个数及类型 含有5个值为2的链表
forward_list<int> l3(,);
//f.指定赋值区域
forward_list<int> l4(l1.begin(),l1.end());
for(auto i : l)
{
cout<< i << endl;
}
return ;
}
二 与迭代器的使用
由于forward_list的迭代器内指向内存不连续 顾不能做迭代器 "+", "-" 操作
int main()
{
forward_list<int> l = {,,,,,,,,,}; //返回迭代器开始之前的位置
l.before_begin(); //返回第一个元素地址
l.begin(); //返回最后一个元素的下一个位置
l.end(); //返回迭代器开始之前的位置
l.cbefore_begin(); //返回第一个元素地址
l.cbegin(); //返回最后一个元素的下一个位置
l.cend();
return ;
}
三 容量
int main()
{
forward_list<int> l = {,,,,,,,,,}; //返回forward_list是否为空
cout << l.empty() << endl; //forward_list的最大容量
cout << l.max_size() << endl; return ;
}
四 元素访问
int main()
{
forward_list<int> l = {,,,,,,,,,}; //返回第一个元素
cout<< l.front() <<endl; return ;
}
五 操作
int main()
{
forward_list<int> l = {,,,,,,,,,};
iterator<forward_list<int>, int> i;
for(auto i : l)
{ cout << i << " ";
}
cout<<"初始化"<<endl; //给l赋值成10个1
l.assign(, );
for(auto i : l)
{
cout << i << " ";
}
cout<<"assign()"<<endl; //前段插入0
l.push_front();
for(auto i : l)
{
cout << i << " ";
}
cout<<"push_front()"<<endl; //在头部插入一组 参数为emplace_front(initializer_list<>) 初始化1
l.emplace_front();
for(auto i : l)
{
cout << i << " ";
}
cout<<"emplace_front()"<<endl; //弹出第一个元素
l.pop_front();
for(auto i : l)
{
cout << i << " ";
}
cout<<"pop_front()"<<endl; //在指定位置后面插入一组数据
l.emplace_after(l.begin(), );
for(auto i : l)
{
cout << i << " ";
}
cout<<"emplace_after()"<<endl; //在指定位置后面插入一组数据
l.insert_after(l.begin(), );
for(auto i : l)
{
cout << i << " ";
}
cout<<"insert_after()"<<endl; //在指定位置之后插入元素
l.insert_after(l.begin(), );
for(auto i : l)
{
cout << i << " ";
}
cout<<"insert_after()"<<endl; //删除指定位置
l.erase_after(l.begin(),l.end());
for(auto i : l)
{
cout << i << " ";
}
cout<<"erase_after()"<<endl; //交换并释l2
forward_list<int> l2 = {,,,};
l.swap(l2);
for(auto i : l)
{
cout << i << " ";
}
cout<<"swap()"<<endl; //重新设定内存,不足补齐, 超过弹出尾部
l.resize(,);
for(auto i : l)
{
cout << i << " ";
}
cout<<"resize()"<<endl; //清空
l.clear();
for(auto i : l)
{
cout << i << " ";
}
cout<<"clear()"<<endl; return ;
}
六 修改操作
int main()
{
//指定位置拼接链表
forward_list<int> l = {,,,,,,,,,};
forward_list<int> l1 = {,,,,,,,,,,}; l.splice_after(l.before_begin(), l1);
for(auto i : l)
{
cout << i << " ";
}
cout<<"splice_after()"<<endl; //删除指定元素
l.remove();
for(auto i : l)
{
cout << i << " ";
}
cout<<"remove()"<<endl; //按指定条件删除
l.remove_if([](int x){return x<;});
for(auto i : l)
{
cout << i << " ";
}
cout<<"remove_if()"<<endl; //排序 <
l.sort();
for(auto i : l)
{
cout << i << " ";
}
cout<<"sort(<)"<<endl; l.sort([](int first, int second){return first > second;});
for(auto i : l)
{
cout << i << " ";
}
cout<<"sort(>)"<<endl; //删除重复元素
l.unique();
for(auto i : l)
{
cout << i << " ";
}
cout<<"unique()"<<endl; forward_list<int> l2 = {,,,,,,,,,,,,}; //按指定要求删除元素(排序后)
l2.unique([](int x, int y) { return (x == y) && (x < );});
for(auto i : l2)
{
cout << i << " ";
}
cout<<"unique([])"<<endl; forward_list<int> l3 = {,,,};
forward_list<int> l4 = {,,,};
//合并两个有序forward_list 合并后仍然有序
l3.merge(l4);
for(auto i : l3)
{
cout << i << " ";
}
cout<<"merge()"<<endl; //翻转
l3.reverse();
for(auto i : l3)
{
cout << i << " ";
}
cout<<"reverse()"<<endl; //交换 多退少补 并释放l
l3.swap(l);
for(auto i : l3)
{
cout << i << " ";
}
cout<<"reverse()"<<endl; return ;
}
STL标准库-容器-forward_list的更多相关文章
- STL标准库-容器-set与map
STL标准库-容器-set与multiset C++的set https://www.cnblogs.com/LearningTheLoad/p/7456024.html STL标准库-容器-map和 ...
- STL标准库-容器-set与multiset
技术在于交流.沟通,转载请注明出处并保持作品的完整性. set与multiset关联容器 结构如下 set是一种关联容器,key即value,value即key.它是自动排序,排序特点依据key se ...
- STL标准库-容器-deque
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性. deque双向开口可进可出的容器 我们知道连续内存的容器不能随意扩充,因为这样容易扩充别人那去 deque却可以,它创造了内存 ...
- STL标准库-容器-vector
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性. 向量容器vector是一个动态数组,内存连续,它是动态分配内存,且每次扩张的原来的二倍. 他的结构如下 一 定义 vector ...
- STL标准库-容器-list
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性. list 表示非连续的内存区域,并通过一对指向首尾元素的指针双向链接起来,从而允许向前和向后两个方向进行遍历.在list 的任 ...
- STL标准库-容器适配器
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 上一节介绍了仿函数适配器,这节主要介绍容器适配器和迭代器适配器的概念,其实容器适配器和迭代器其适配器就是封装了一些其他class ...
- STL标准库-容器-rb_tree
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 红黑树,关联式容器底层实现(map set),在使用中基本运用不到,但是还是想了解一下他的运作方式 Red_Black tree ...
- STL标准库-容器-unordered_set
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 unordered_set与与unordered_map相似,这次主要介绍unordered_set unordered_set ...
- STL标准库-容器-map和multimap
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 map与multimap为关联容器,结构如下 map底层实现依然是rb_tree 他的data可以改,但是key不能改,因此ma ...
随机推荐
- IOS使用Core-Plot画折线图
关于Core-Plot的配置.大家能够參考我的上一篇博客:http://1.wildcat.sinaapp.com/?p=99 版权全部.转载请注明原文转自:http://blog.csdn.net/ ...
- Spark Core (一) 什么是RDD的Transformation和Action以及Dependency(转载)
1. Spark的RDD RDD(Resilient Distributed Datasets),弹性分布式数据集,是对分布式数据集的一种抽象. RDD所具备5个主要特性: 一组分区列表 计算每一个数 ...
- Django REST framework 之 API认证
RESTful API 认证 和 Web 应用不同,RESTful APIs 通常是无状态的, 也就意味着不应使用 sessions 或 cookies, 因此每个请求应附带某种授权凭证,因为用户授权 ...
- jQuery-添加、移出事件
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...
- js判断用户是在PC端或移动端访问
js如何判断用户是在PC端和还是移动端访问. 最近一直在忙我们团队的项目“咖啡之翼”,在这个项目中,我们为移动平台提供了一个优秀的体验.伴随Android平台的红火发展.不仅带动国内智能手机行业,而 ...
- ES6基本语法和一些面向对象的知识
声明变量 var 使用var声明变量会将变量的声明提到全局,在局部作用域声明的在全局也能打印 { var a = 12; } // 变量提升 var会将变量的声明提到全局 console.log(a) ...
- 4.1 Routing -- Introduction
一.Routing 1. 当用户与应用程序交互时,它会经过很多状态.Ember.js为你提供了有用的工具去管理它的状态和扩展你的app. 2. 要理解为什么这是重要的,假设我们正在编写一个Web应用程 ...
- 20155316 2016-2017-2 《Java程序设计》第8周学习总结
教材学习内容总结 课堂部分要点 数据结构与算法 与 Java相结合 collection API:数据结构 crypt:密码学 操作系统 考试部分重点 实验楼:Linux第四节 教材:第6章.第14章 ...
- INNODB锁(2)
在上一篇文章写了锁的基本概述以及行锁的三种形式,这一篇的主要内容如下: 一致性非锁定读 自增长与锁 外键和锁 一致性性非锁定读 一致性非锁定读是InnoDB通过多版本并发控制(MVCC,multi v ...
- ZLYZD团队第四周项目总结
ZLYD团队第四周项目总结 项目进展 将Wall.java.Gold.java.Player.java.Fruit.java.Enemy.java.Ticker.java和Packman.java七个 ...