GEEK学习笔记— —STL容器forward_list

简介

在头文件 <forward_forward_list> 中定义

namespace std
{
    template <typename T,
            typename Allocator = allocator<T> >
class forward_forward_list;
}

单向列表是一个容器,支持在其任何地方快速插入和删除元素,不支持快速的随机访问。它被实现为单向链表,和C中它的实现相比,基本上不会有任何开销。

当不需要双向迭代的时候,与forward_list相比,该容器具有更高的空间利用率。

插入和删除操作不会使指向其他元素指针、引用和迭代器失效。

forward_list操作

构造、复制与析构

forward_list<Elem> c //默认构造函数;创建一个空forward_list

forward_list<Elem> c(c2) //复制构造函数;创建一个新的forward_list作为c2的副本(所有元素都被复制)

forward_list<Elem> c = c2 //复制构造函数;创建一个新的forward_list作为c2的副本(所有元素都被复制)

forward_list<Elem> c(rv) //移动构造函数;使用右值对象rv创建一个新forward_list

forward_list<Elem> c = rv //移动构造函数;使用右值对象rv创建一个新forward_list

forward_list<Elem> c(n) //使用默认构造函数创建含有n个元素的forward_list

forward_list<Elem> c(n,elem) //创建一个forward_list,并使用n个elem进行初始化

forward_list<Elem> c(beg,end) //创建一个forward_list,并使用beg到end范围内的值进行初始化

forward_list<Elem> c(initlist) //创建一个forward_list,并使用初始化列表进行初始化

forward_list<Elem> c = initlist //创建一个forward_list,并使用初始化列表进行初始化

c.~forward_list() //销毁所有元素并释放内存

非变动性操作

c.empty() //判断容器是否为空

c.max_size() //返回可容纳的元素最大数量

c1 == c2 //判断c1与c2是否相等

c1 != c2 //判断c1与c2是否不相等,等同于!(c1==c2)

c1 < c2 //判断c1是否小于c2

c1 > c2 //判断c1是否大于c2

c1 <= c2 //判断c1是否小于等于c2

c1 >= c2 //判断c1是否大于等于c2

赋值

c = c2 //将c2所有元素赋值给c

c = rv //将右值对象rv的所有元素移动赋值给c

c = initlist //使用初始化列表进行赋值

c.assign(initlist) //使用初始化列表进行赋值

c.assign(n,elem) //使用n个elem元素进行赋值

c.assign(beg,end) //使用beg到end范围内的元素进行赋值

c1.swap(c2) //交换c1和c2的数

swap(c1,c2) //交换c1和c2的数

元素存取

c.front() //返回第一个元素,不检查第一个元素是否存在

迭代器相关函数

c.begin() //返回一个双向迭代器,指向第一个元素

c.end() //返回一个双向迭代器,指向最后一个元素

c.cbegin() //返回一个双向常迭代器,指向第一个元素

c.cend() //返回一个双向常迭代器,指向最后一个元素

c.before_begin() //返回一个前向迭代器,指向第一个元素之前的位置

c.cbefore_begin() //返回一个前向常迭代器,指向第一个元素之前的位置

插入和移除元素

c.push_front(elem) //在头部添加一个elem副本

c.pop_front() //移除头部元素(但不回传)

c.insert_after(pos,elem) //在迭代器位置之后插入一个elem副本,并返回新元素的位置

c.insert_after(pos,n,elem) //在迭代器位置之后插入n个elem副本,并返回第一个新元素的位置;若无新插入值,返回原位置

c.insert_after(pos,beg,end) //在迭代器位置之后插入范围beg到end的所有元素的副本,并返回第一个新元素的位置;若无新插入值,返回原位置

c.insert_after(pos,initforward_list) //在迭代器位置之后插入初始化列表的所有元素的副本,并返回第一个新元素的位置;若无新插入值,返回原位置

c.emplace_after(pos,args...) //在迭代器位置之后插入一个使用args初始化的元素副本,并返回新元素的位置

c.emplace_front(args...) //在头部添加一个使用args初始化的元素副本,无返回值

c.erase_after(pos) //移除迭代器位置的元素,无返回值

c.erase_after(beg,end) //移除beg到end范围内的所有元素,无返回值

c.remove(val) //移除所有值为val的元素

c.remove_if(op) //移除所有满足op条件的元素

c.resize(num) //将元素数量设为num(如果size()增大,多出来的元素使用默认构造函数创建)

c.resize(num,elem) //将元素数量设为num(如果size()增大,多出来的元素都是elem的副本)

c.clear() //移除所以元素,清空容器

特殊修改操作

c.unique() //若存在相邻而数值相等的元素,移除重复元素

c.unique(op) //若存在相邻而数值相等的元素,且满足op条件时,移除重复元素

c.splice_after(pos,c2) //将c2内的所有元素转移到c1内pos所指的位置之后

c.splice_after(pos,c2,c2pos) //将c2内c2pos之后的元素转移到c1内pos所指的位置之后

c.splice_after(pos,c2,c2beg,c2end) //将c2内从c2beg到c2end区间内的所有元素转移到c1内pos所指的位置之后

c.sort() //以operator<为准则,对所有元素排序

c.sort(op)  //以op为准则,对所有元素排序

c.merge(c2) //假设c1和c2都包含已序元素,将c2的全部元素转移到c1.并保证合并后的forward_list仍为已序

c.merge(c2,op) //假设c1和c2都包含op原则下已序元素,将c2的全部元素转移到c1.并保证合并后的forward_list在op原则下仍为已序

c.reverse() //将所有元素反序

栗子

#include <forward_list>
#include <iostream>
#include <algorithm>
#include <iterator>
#include <string>

using namespace std;

void printLists (const string& s, const forward_list<int>& l1,
                 const forward_list<int>& l2)
{
    cout << s << endl;
    cout << " list1: ";
    copy (l1.cbegin(), l1.cend(), ostream_iterator<int>(cout," "));
    cout << endl << " list2: ";
    copy (l2.cbegin(), l2.cend(), ostream_iterator<int>(cout," "));
    cout << endl;
}

int main()
{
    //创建两个前向列表
    forward_list<int> list1 = { 1, 2, 3, 4 };
    forward_list<int> list2 = { 77, 88, 99 };
    printLists ("initial:", list1, list2);

    //在list2头部插入6个新元素
    list2.insert_after(list2.before_begin(),99);
    list2.push_front(10);
    list2.insert_after(list2.before_begin(), {10,11,12,13} );
    printLists ("6 new elems:", list1, list2);

    //在list1头部插入list2全部元素
    list1.insert_after(list1.before_begin(),
                       list2.begin(),list2.end());
    printLists ("list2 into list1:", list1, list2);

    //删除list2的第二个元素,删除list2中值为99的元素后面的所有元素
    list2.erase_after(list2.begin());
    list2.erase_after(find(list2.begin(),list2.end(),
                           99),
                      list2.end());
    printLists ("delete 2nd and after 99:", list1, list2);

    //对list1排序,并把list1赋值给list2,对list2去重
    list1.sort();
    list2 = list1;
    list2.unique();
    printLists ("sorted and unique:", list1, list2);

    //把已序的list2合并到list1中
    list1.merge(list2);
    printLists ("merged:", list1, list2);

    return 0;
}

}

输出

initial:
list1: 1 2 3 4
list2: 77 88 99
6 new elems:
list1: 1 2 3 4
list2: 10 11 12 13 10 99 77 88 99
list2 into list1:
list1: 10 11 12 13 10 99 77 88 99 1 2 3 4
list2: 10 11 12 13 10 99 77 88 99
delete 2nd and after 99:
list1: 10 11 12 13 10 99 77 88 99 1 2 3 4
list2: 10 12 13 10 99
sorted and unique:
list1: 1 2 3 4 10 10 11 12 13 77 88 99 99
list2: 1 2 3 4 10 11 12 13 77 88 99
merged:
list1: 1 1 2 2 3 3 4 4 10 10 10 11 11 12 12 13 13 77 77 88 88 99 99 99
list2:
时间: 2024-10-09 11:45:31

GEEK学习笔记— —STL容器forward_list的相关文章

GEEK学习笔记— —STL容器list

简介 在头文件 <list> 中定义 namespace std { template <typename T, typename Allocator = allocator<T> > class list; } 列表是一个容器,它支持任何位置的元素快速插入和删除,不支持快速的随机访问.它被实现为双向的链表. 与forward_list相比,它提供双向迭代的能力,但空间效率更低. 插入和删除操作不会使指向其他元素指针.引用和迭代器失效. list操作 构造.复制与析构

GEEK学习笔记— —STL容器之选用

默认情况下,选用vector,内部数据结构最简单,允许随机存取. 如果经常要在序列头部和尾部插入和删除元素,应该使用deque.如果希望元素被删除时,容器能自动缩减内存,那么也要选deque.此外,由于vector通常采用一个内存块存放元素,而deque采用多个内存块,后者可包含更多元素. 如果需要经常在容器中段执行元素的插入.删除或移动,可考虑list.list提供特殊成员函数,可在常数时间将元素从A容器转移到B容器.但由于list不支持随机存取,如果只知道list的头部却要访问中段元素,性能

GEEK学习笔记— —STL容器之无序容器(Unordered Container)

简介 在头文件<unordered_set>和<unordered_Unord> 中定义 namespace std { template <typename T, typename Hash = hash<T>, typename EqPred = equal_to<T>, typename Allocator = allocator<T> > class unordered_set; template <typename T

GEEK学习笔记— —STL容器map和multimap

简介 在头文件<map> 中定义 namespace std { template <typename Key, typename T, typename Compare = less<Key>, typename Allocator = allocator<pair<const Key,T> > > class map; template <typename Key, typename T, typename Compare = less

C++学习笔记5 容器

1.  使用assign assign 操作首先删除容器中所有的元素,然后将其参数所指定的新元素插入到该容器中.与复制容器元素的构造函数一样,如果两个容器类型相同,其元 素类型也相同,就可以使用赋值操作符(=)将一个容器赋值给另一个容器.如果在不同(或相同)类型的容器内,元素类型不相同但是相互兼容,则其赋值运 算必须使用assign 函数.例如,可通过assign 操作实现将vector 容器中一段char* 类型的元素赋给string 类型list 容器. 由于assign 操作首先删除容器中

STL学习笔记— —无序容器(Unordered Container)

简单介绍 在头文件<unordered_set>和<unordered_map> 中定义 namespace std { template <typename T, typename Hash = hash<T>, typename EqPred = equal_to<T>, typename Allocator = allocator<T> > class unordered_set; template <typename T

STL学习笔记— —特殊容器queue

简介 在头文件<queue> 中定义 namespace std { template <typename T, typename Container = deque<T>> class queue; } queue就是数据结构里队列的实现,先进先出.定义中的第二个参数用来定义queue内部存放元素的实际容器,可以是任何序列式容器,默认容器为deque. 实际上queue也只是很单纯地把各项操作转化为内部容器的对应调用. 核心接口 push() //将一个元素置入que

STL学习笔记— —特殊容器priority_queue

简介 在头文件<queue> 中定义 namespace std { template <typename T, typename Container = vector<T>, typename Compare = less<typename Container::value_type>> class priority_queue; } priority_queue与queue很类似,但是priority_queue内部根据某种规则进行了排序,所以既不是先进

C++学习笔记——STL(标准模板库)

1.首先.需要学习C++ 模板的概念 2.C++ STL(标准模板库)是一套功能强大的 C++ 模板类,提供了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构,如向量.链表.队列.栈. 3.C++ 标准模板库的核心包括以下三个组件: 组件 描述 容器(Containers) 容器是用来管理某一类对象的集合.C++ 提供了各种不同类型的容器,比如 deque.list.vector.map 等. 算法(Algorithms) 算法作用于容器.它们提供了执行各种操作的方式,