c++的学习之路:14、list(1)

本章讲一下如何使用list

一、list介绍

首先还是看一看官方文档的介绍如下图,如下方五点:

  1. list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。

  2. list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向 其前一个元素和后一个元素。

  3. list与forward_list非常相似:最主要的不同在于forward_list是单链表,只能朝前迭代,已让其更简单高 效。

  4. 与其他的序列式容器相比(array,vector,deque),list通常在任意位置进行插入、移除元素的执行效率 更好。

  5. 与其他序列式容器相比,list和forward_list最大的缺陷是不支持任意位置的随机访问,比如:要访问list 的第6个元素,必须从已知的位置(比如头部或者尾部)迭代到该位置,在这段位置上迭代需要线性的时间 开销;list还需要一些额外的空间,以保存每个节点的相关联信息(对于存储类型较小元素的大list来说这 可能是一个重要的因素)

在图二就是一些参数,可以明显看到没有【】,因为list就是相当于一个带头双向链表,参数和之前学习的差不多,就不详细讲了。

二、增

如下方代码就是就创建了一个链表为l1和l2进行尾插和头插然后在利用for进行打印。

void Test1()

{

list<int> l1;

l1.push_back(1);

l1.push_back(2);

l1.push_back(3);

l1.push_back(4);

list<int> l2;

l2.push_front(1);

l2.push_front(2);

l2.push_front(3);

l2.push_front(4);

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

for (auto li : l2)

{

cout << li << ' ';

}

cout << endl;

}

三、删

如下就是先尾删打印在进行头删打印,代码和测试如下。

void Test2()

{

list<int> l1;

l1.push_back(1);

l1.push_back(2);

l1.push_back(3);

l1.push_back(4);

l1.push_back(5);

l1.push_back(6);

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

l1.pop_back();

l1.pop_back();

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

l1.pop_front();

l1.pop_front();

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

}

四、查和改

下方代码就是利用find函数进行插在,找到了3然后返回位置给pos在这个地方进行插入30,然后在查找30再把这个删掉。

void Test3()

{

list<int> l1;

l1.push_back(1);

l1.push_back(2);

l1.push_back(3);

l1.push_back(4);

l1.push_back(5);

l1.push_back(6);

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

auto pos = find(l1.begin(),l1.end(),3);

l1.insert(pos, 30);

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

pos= find(l1.begin(), l1.end(), 30);

l1.erase(pos);

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

}

五、交换

交换两个链表的数值,这个原理就是交换头指针,如下方代码所示。

void Test4()

{

list<int> l1;

l1.push_back(1);

l1.push_back(2);

l1.push_back(3);

l1.push_back(4);

l1.push_back(5);

l1.push_back(6);

list<int> l2;

l2.push_back(10);

l2.push_back(20);

l2.push_back(30);

l2.push_back(40);

l2.push_back(50);

l2.push_back(60);

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

for (auto li : l2)

{

cout << li << ' ';

}

cout << endl;

l1.swap(l2);

for (auto li : l1)

{

cout << li << ' ';

}

cout << endl;

for (auto li : l2)

{

cout << li << ' ';

}

cout << endl;

}

六、代码

#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
#include <list>
using namespace std;

void Test1()
{
	list<int> l1;
	l1.push_back(1);
	l1.push_back(2);
	l1.push_back(3);
	l1.push_back(4);
	list<int> l2;
	l2.push_front(1);
	l2.push_front(2);
	l2.push_front(3);
	l2.push_front(4);
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
	for (auto li : l2)
	{
		cout << li << ' ';
	}
	cout << endl;
}

void Test2()
{
	list<int> l1;
	l1.push_back(1);
	l1.push_back(2);
	l1.push_back(3);
	l1.push_back(4);
	l1.push_back(5);
	l1.push_back(6);
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
	l1.pop_back();
	l1.pop_back();
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
	l1.pop_front();
	l1.pop_front();
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
}

void Test3()
{
	list<int> l1;
	l1.push_back(1);
	l1.push_back(2);
	l1.push_back(3);
	l1.push_back(4);
	l1.push_back(5);
	l1.push_back(6);
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
	auto pos = find(l1.begin(),l1.end(),3);
	l1.insert(pos, 30);
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
	pos= find(l1.begin(), l1.end(), 30);
	l1.erase(pos);
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
}

void Test4()
{
	list<int> l1;
	l1.push_back(1);
	l1.push_back(2);
	l1.push_back(3);
	l1.push_back(4);
	l1.push_back(5);
	l1.push_back(6);
	list<int> l2;
	l2.push_back(10);
	l2.push_back(20);
	l2.push_back(30);
	l2.push_back(40);
	l2.push_back(50);
	l2.push_back(60);
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
	for (auto li : l2)
	{
		cout << li << ' ';
	}
	cout << endl;
	l1.swap(l2);
	for (auto li : l1)
	{
		cout << li << ' ';
	}
	cout << endl;
	for (auto li : l2)
	{
		cout << li << ' ';
	}
	cout << endl;
}

int main()
{
	Test4();
}
相关推荐
易码智能7 分钟前
【EtherCATBasics】- KRTS C++示例精讲(2)
开发语言·c++·kithara·windows 实时套件·krts
一只自律的鸡8 分钟前
C语言项目 天天酷跑(上篇)
c语言·开发语言
程序猿000001号10 分钟前
使用Python的Seaborn库进行数据可视化
开发语言·python·信息可视化
ཌ斌赋ད13 分钟前
FFTW基本概念与安装使用
c++
一个不正经的林Sir15 分钟前
C#WPF基础介绍/第一个WPF程序
开发语言·c#·wpf
API快乐传递者20 分钟前
Python爬虫获取淘宝详情接口详细解析
开发语言·爬虫·python
公众号Codewar原创作者22 分钟前
R数据分析:工具变量回归的做法和解释,实例解析
开发语言·人工智能·python
赵钰老师24 分钟前
基于R语言APSIM模型应用及批量模拟(精细农业、水肥管理、气候变化、粮食安全、土壤碳周转、环境影响、农业可持续性、农业生态等)
开发语言·数据分析·r语言
lly20240641 分钟前
Highcharts 饼图:数据可视化利器
开发语言
薄荷故人_1 小时前
从零开始的C++之旅——红黑树封装map_set
c++