技术在于交流、沟通,本文为博主原创文章转载请注明出处并保持作品的完整性。

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的更多相关文章

  1. STL标准库-容器-set与map

    STL标准库-容器-set与multiset C++的set https://www.cnblogs.com/LearningTheLoad/p/7456024.html STL标准库-容器-map和 ...

  2. STL标准库-容器-set与multiset

    技术在于交流.沟通,转载请注明出处并保持作品的完整性. set与multiset关联容器 结构如下 set是一种关联容器,key即value,value即key.它是自动排序,排序特点依据key se ...

  3. STL标准库-容器-deque

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性. deque双向开口可进可出的容器 我们知道连续内存的容器不能随意扩充,因为这样容易扩充别人那去 deque却可以,它创造了内存 ...

  4. STL标准库-容器-vector

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性. 向量容器vector是一个动态数组,内存连续,它是动态分配内存,且每次扩张的原来的二倍. 他的结构如下 一 定义 vector ...

  5. STL标准库-容器-list

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性. list 表示非连续的内存区域,并通过一对指向首尾元素的指针双向链接起来,从而允许向前和向后两个方向进行遍历.在list 的任 ...

  6. STL标准库-容器适配器

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 上一节介绍了仿函数适配器,这节主要介绍容器适配器和迭代器适配器的概念,其实容器适配器和迭代器其适配器就是封装了一些其他class ...

  7. STL标准库-容器-rb_tree

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 红黑树,关联式容器底层实现(map set),在使用中基本运用不到,但是还是想了解一下他的运作方式 Red_Black tree ...

  8. STL标准库-容器-unordered_set

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 unordered_set与与unordered_map相似,这次主要介绍unordered_set unordered_set ...

  9. STL标准库-容器-map和multimap

    技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 map与multimap为关联容器,结构如下 map底层实现依然是rb_tree 他的data可以改,但是key不能改,因此ma ...

随机推荐

  1. win安装mysql

    在这讲解的是有关于通过zip解压安装MySQL的方法.有看了网上的其它的教程,讲的有些不够完善,也自己写一篇简述一下.个人还是建议看官方的参考文档非常之详细:https://dev.mysql.com ...

  2. centos LAMP第一部分-环境搭建 Linux软件删除方式,mysql安装,apache,PHP,apache和php结合,phpinfo页面,ldd命令 第十九节课

    centos LAMP第一部分-环境搭建  Linux软件删除方式,mysql安装,apache,PHP,apache和php结合,phpinfo页面,ldd命令 第十九节课 打命令之后可以输入: e ...

  3. [css]网站骨架布局作业

    实现效果图: 代码实现 第一次写的时候不知道如何下手, 后来摸清规律了,由大到小. 由全局到局部 第一次还遇到区块命名问题, 和哪个该怎么划分问题 第一次还遇到由于划分不规整,所以有些代码没达到预期的 ...

  4. 记一次mysql启动不了的问题

    在linux上用的是xampp,mysql启动没有报任何错误,但就是查找不到进程,于是找mysql错误日志,日志在哪?在lampp/var/mysql 以.err结尾的文件里.里面内容如下; /opt ...

  5. 超全超详细的 ADB 用法大全

    原文地址:原文地址 基本用法 命令语法 为命令指定目标设备 启动/停止 查看 adb 版本 以 root 权限运行 adbd 指定 adb server 的网络端口 设备连接管理 查询已连接设备/模拟 ...

  6. [LeetCode]83. Remove Duplicates from Sorted List(排序链表去重)

    Given a sorted linked list, delete all duplicates such that each element appear only once. For examp ...

  7. 2018 Multi-University Training Contest 3 Solution

    A - Problem A. Ascending Rating 题意:给出n个数,给出区间长度m.对于每个区间,初始值的max为0,cnt为0.遇到一个a[i] > ans, 更新ans并且cn ...

  8. hdu5012 圆环相交面积

    题中给了 两个同心圆, 一个大圆一个小圆,然后再给了一个大圆一个小圆也是同心圆,求这两个圆环相交的面积,用两个大圆面积减去两倍大小圆面积交加上两个小圆面积交,就ok了 这里算是坑明白了 使用acos的 ...

  9. jmeter dubbo接口测试

    说在前面,测试熔断降级系统时,要求测试一下对应的dubbo接口性能 1.安装Jmeter 2.将dubbo依赖包下载好放在jmeter路径/lib/ext下, 3.打开jmeter,测试计划下新建线程 ...

  10. appium问题解决

    ppium 1.4.16 版本 测试安卓7.0 提示AppiumSettings.Unlock.AndroidInputManager 安装 修改 C:\Program Files (x86)\App ...