#include <iostream>
#include <string>
#include <forward_list> using namespace std; // https://zh.cppreference.com/w/cpp/container/forward_list std::ostream& operator<<(std::ostream& ostr, const std::forward_list<int>& list)
{
for (auto &i : list) {
ostr << " " << i;
}
return ostr;
} class item
{
public:
item() = delete; item(const int& a, const int& b)
: m_a(a), m_b(b)
{} bool operator< (const item& comp) const
{
return m_a*m_b < comp.m_a*comp.m_b;
} bool operator== (const item& comp) const
{
return m_a==comp.m_a && m_b==comp.m_b;
} private:
int m_a;
int m_b;
}; bool compAB(int a, int b)
{
return a + 1 < b;
} int main()
{
int a[] = { 1,2,3 };
forward_list<int> lis;
forward_list<int> lis2(4);
forward_list<int> lis3(4, 5);
forward_list<item> lis5(4, item(1, 2));
forward_list<item> lis6(4, { 1, 2 });
forward_list<item> lis7(lis6);
forward_list<int> lis8(a, a + 3);
forward_list<item> lis9(lis7.begin(), lis7.end());
forward_list<int> lis4({ 1,2,3 }); ////////////////////////////////////////////////////////////////////////// int v_front = lis4.front(); std::forward_list<int>::iterator
it_bb = lis4.before_begin(); // 返回指向第一个元素之前迭代器
auto cit_bb = lis4.cbefore_begin(); auto it_b = lis4.begin();
auto cit_b = lis4.cbegin(); auto it_e = lis4.end();
auto cit_e = lis4.cend(); ////////////////////////////////////////////////////////////////////////// // 没有 size bool isEmpty = lis4.empty();
size_t max_size = lis4.max_size(); // 并非实际可以申请到的大小 ////////////////////////////////////////////////////////////////////////// lis4.clear();
lis4 = { 1,2,3 }; // iterator insert_after(const_iterator pos, const T& value);
lis4.insert_after(lis4.before_begin(), 77); // 78 1 2 3
lis4.insert_after(lis4.begin(), 78); // 77 78 1 2 3 // iterator insert_after( const_iterator pos, size_type count, const T& value );
lis4.insert_after(lis4.before_begin(), 2, 79); // 79 79 78 1 2 3 forward_list<int> lis10({ 10,20,30 });
// template< class InputIt >
// iterator insert_after(const_iterator pos, InputIt first, InputIt last);
lis4.insert_after(lis4.before_begin(), lis10.begin(), lis10.end()); // 10 20 30 79 79 78 1 2 3 lis4.insert_after(lis4.before_begin(), { 11,22 }); // 11 22 10 20 30 79 79 78 1 2 3 ////////////////////////////////////////////////////////////////////////// // 在容器中的指定位置后插入新元素。原位构造元素,即不进行复制或移动操作。
lis4.emplace_after(lis4.begin(), 555); // 11 555 22 10 20 30 79 79 78 1 2 3 // iterator erase_after( const_iterator pos );
// 从容器移除指定元素。
lis4.erase_after(lis4.begin()); // 11 22 10 20 30 79 79 78 1 2 3 ////////////////////////////////////////////////////////////////////////// lis4.push_front(666); // 666 11 22 10 20 30 79 79 78 1 2 3
lis4.emplace_front(777); // 777 666 11 22 10 20 30 79 79 78 1 2 3
lis4.pop_front(); // 666 11 22 10 20 30 79 79 78 1 2 3 ////////////////////////////////////////////////////////////////////////// lis4.resize(2); // 缩小,保留前两个
lis4.resize(5); // 放大,补默认值,这里是 0 lis4.swap(lis8); ////////////////////////////////////////////////////////////////////////// // merge: 排序后,把 2 的元素 移动 到 1 中。
{
std::forward_list<int> list1 = { 5,9,0,1,3,10,0 };
std::forward_list<int> list2 = { 8,7,2,6,4 }; list1.sort();
list2.sort();
std::cout << "list1: " << list1 << "\n";
std::cout << "list2: " << list2 << "\n";
list1.merge(list2); // 必须是有序的,元素的 < 必须有定义。// lis2 变为空
std::cout << "merged: " << list1 << "\n";
} {
std::forward_list<int> list1 = { 5,9,0,1,3 };
std::forward_list<int> list2 = { 8,7,2,6,4 }; list1.sort();
list2.sort();
std::cout << "list1: " << list1 << "\n";
std::cout << "list2: " << list2 << "\n";
list1.merge(list2, [](int a, int b) { return a + 1 < b; }); // 自定义 < 的比较方法,lambda 表达式。// lis2 变为空
std::cout << "merged: " << list1 << "\n";
} {
std::forward_list<int> list1 = { 5,9,0,1,3 };
std::forward_list<int> list2 = { 8,7,2,6,4 }; list1.sort();
list2.sort();
std::cout << "list1: " << list1 << "\n";
std::cout << "list2: " << list2 << "\n";
list1.merge(list2, compAB); // 函数名。// lis2 变为空
std::cout << "merged: " << list1 << "\n";
} ////////////////////////////////////////////////////////////////////////// {
forward_list<int> lis11({ 10,20,30 });
forward_list<int> lis12({ 101,201,301 }); // void splice_after( const_iterator pos, forward_list& other );
lis11.splice_after(lis11.before_begin(), lis12); // 101,201,301 10,20,30
} {
forward_list<int> lis11({ 10,20,30 });
forward_list<int> lis12({ 101,201,301 });
// void splice_after( const_iterator pos, forward_list& other, const_iterator it );
lis11.splice_after(lis11.before_begin(), lis12, lis12.begin()); // 201 10,20,30 // 迭代器的后一个元素
} {
forward_list<int> lis11({ 10,20,30 });
forward_list<int> lis12({ 101,201,301 });
auto it12 = lis12.begin();
std::advance(it12, 2);
// void splice_after( const_iterator pos, forward_list& other,
// const_iterator first, const_iterator last );
lis11.splice_after(lis11.before_begin(), lis12, lis12.before_begin(), it12); // 101,201 10,20,30 // 最后的两个迭代器,是开集
} ////////////////////////////////////////////////////////////////////////// {
std::forward_list<int> l = { 1,100,2,3,10,1,11,-1,12 }; l.remove(1); // 移除两个等于 1 的元素
l.remove_if([](int n) { return n > 10; }); // 移除全部大于 10 的元素 for (int n : l) {
std::cout << n << ' ';
}
std::cout << '\n';
} ////////////////////////////////////////////////////////////////////////// // 逆转容器中的元素顺序。不非法化任何引用或迭代器。
forward_list<int> lis13({ 10,20,30 });
lis13.reverse(); //////////////////////////////////////////////////////////////////////////
// 从容器移除所有 相邻 的重复元素。只留下相等元素组中的第一个元素。
{
std::forward_list<int> x = { 1, 2, 2, 3, 3, 2, 1, 1, 2 }; std::cout << "contents before:";
for (auto val : x)
std::cout << ' ' << val;
std::cout << '\n'; x.unique(); // 1 2 3 2 1 2
std::cout << "contents after unique():";
for (auto val : x)
std::cout << ' ' << val;
std::cout << '\n'; return 0;
} //////////////////////////////////////////////////////////////////////////
// sort
{
std::forward_list<int> list = { 8,7,5,9,0,1,3,2,6,4 }; std::cout << "before: " << list << "\n";
list.sort(); // 默认升序
std::cout << "ascending: " << list << "\n";
list.sort(std::greater<int>()); // 降序
std::cout << "descending: " << list << "\n"; // 类,要重载 <
// 或者,传参 lambda 表达式
} }

  

C++ std::forward_list 基本用法的更多相关文章

  1. C++ std::forward_list

    std::forward_list template < class T, class Alloc = allocator > class forward_list; Forward li ...

  2. C++ std::list 基本用法

    #include <iostream> #include <string> #include <list> using namespace std; // http ...

  3. C++ std::map::erase用法及其陷阱

    1.引入: STL的map中有一个erase方法用来从一个map中删除制定的节点 eg: map<string,string> mapTest; typedef map<string ...

  4. QLinkedList和std::forward_list

    forward_list forward_list是C++11版本才有的.forward_list被实现为单链表,而list是一个双向链表,所以forward_list要比list高效一些.forwa ...

  5. QLinkedList和std::forward_list(都是双向链表,不支持operator[],好处可能是插入和删除都比较快)

    forward_list forward_list是C++11版本才有的.forward_list被实现为单链表,而list是一个双向链表,所以forward_list要比list高效一些.forwa ...

  6. C++ std::pair的用法

    1 pair的应用 pair是将2个数据组合成一个数据,当需要这样的需求时就可以使用pair,如stl中的map就是将key和value放在一起来保存.另一个应用是,当一个函数需要返回2个数据的时候, ...

  7. std::shared_ptr 和 std::weak_ptr的用法以及引用计数的循环引用问题

    在std::shared_ptr被引入之前,C++标准库中实现的用于管理资源的智能指针只有std::auto_ptr一个而已.std::auto_ptr的作用非常有限,因为它存在被管理资源的所有权转移 ...

  8. C++ std::list 和 std::forward_list 的差别及其成员函数差异对比

    主要差别: list 是双向链表,forward_list 是双向链表. 成员函数差异: 函数名 list forward_list back() has no size() has no inser ...

  9. 容器之分类与各种测试(三)——forward_list的用法

    forward_list是C++11规定的新标准单项链表,slist是g++以前的规定的单项链表 例程 #include<stdexcept> #include<string> ...

随机推荐

  1. Kubernetes 应用部署实战

    Kubernetes 应用部署实战 2018-08-08 19:44:56 wuxiangping2017 阅读数 3084  收藏 更多 分类专栏: linux运维与架构师   简介 伙计们,请搬好 ...

  2. 【hibernate】映射可嵌入式组件

    [hibernate]映射可嵌入式组件 转载:https://www.cnblogs.com/yangchongxing/p/10376452.html 可嵌入 Address 类,没有对应的数据表 ...

  3. django----csrf跨站请求伪造 auth组件 settings源码 importlib模块

    目录 importlib模块 csrf跨站请求伪造 form表单发送 ajax发送 csrf装饰器 auth模块 如何创建超级用户(root) 创建用户 校验用户名和密码是否正确 保存用户登录状态 判 ...

  4. 京东云携手HashiCorp,宣布推出Terraform Provider

    2019年4月23日消息,京东云携手云基础设施自动化软件的领导者HashiCorp,宣布推出Terraform Provider for JD Cloud,这意味着用户能够在京东云上轻松使用简单模板语 ...

  5. Python代码编写规范,你真的会吗?

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:yangjiajia123456  最近两年的工作都是和运维相关,有时 ...

  6. ASP.NET操作Excel

    使用NPOI操作Excel,无需Office COM组件 部分代码来自于:https://docs.microsoft.com/zh-tw/previous-versions/ee818993(v=m ...

  7. HTTP认知(请求与响应)

    web的工作是:浏览器发送请求报文 + 服务端返回响应报文 通俗的说一下web工作的一个流程: 浏览器向服务端发送HTTP请求报文:这条请求报文组成由请求行.请求头.请求体三大部分组成: 1.请求行 ...

  8. 闲鱼hu超赞,有赞必回,24小时在线!咸鱼互赞超赞留言评

    有没有在闲鱼上卖东西没有浏览量的人! 我们来一起互赞互相提高彼此宝贝的浏览量,从而更快的促进交易! 我打算建个群,我们可以一起交流下哈! 需要的进入QQ群   : 530980712

  9. k8s采坑记 - 解决二进制安装环境下证书过期问题

    前言 上一篇k8s采坑记 - 证书过期之kubeadm重新生成证书阐述了如何使用kubeadm解决k8s证书过期问题. 本篇阐述使用二进制安装的kubernetes环境,如何升级过期证书? k8s配置 ...

  10. 微软发布ML.NET 1.0

    原文地址:https://devblogs.microsoft.com/dotnet/announcing-ml-net-1-0/ 我们很高兴地宣布今天发布ML.NET 1.0.  ML.NET是一个 ...