当前位置: 首页 > article >正文

【C++】list容器

目录

学习途径

list的使用

list的一些构造

迭代器说明

接口使用

迭代器失效问题

list和vector对比

模拟实现list

迭代器的模拟(重点)

List.h文件


学习途径

在学习list之前,我们可以查询一些相关文档来学习!

文档详情:list文档学习

list的使用

list的一些构造

图:

构造使用示范:

迭代器说明

list中的迭代器和咋们印象中的迭代器一样:

begin指向第一个元素,end指向最后一个元素的后面一个位置!rbegin指向最后一个元素,rbegin指向第一个元素的前一个位置!

使用的时候要注意:

接口使用

常用接口

这里不做代码示范!比较简单!

迭代器失效问题

迭代器失效即迭代器所指向的节点的无效,即该节点被删除了。

因为list的底层结构为带头结点的双向循环链表,因此在list中进行插入 时是不会导致list的迭代器失效的,只有在删除时才会失效,并且失效的只是指向被删除节点的迭代器,其他迭代器不会受到影响。

list和vector对比

模拟实现list

迭代器的模拟(重点)

list的迭代器模拟和vector不一样!

因为list底层是带头的双向链表,而链表底层是节点连接而成的,不是连续的空间!

而vector底层是动态数组,是一块连续的空间!

所以我们如何将这一块一块的空间来遍历它!!!

我们可以用一个类包装它,这个类就叫迭代器,上图理解:

理解了这里,其他就水到渠成了!!!

List.h文件

#include<iostream>
#include<assert.h>
namespace ywc
{
	template<class T>
	struct list_node
	{
		T _data;
		list_node<T>* _next;
		list_node<T>* _prev;
		list_node(const T& data=T())
			:_data(data)
			,_next(nullptr)
			,_prev(nullptr)
		{}
	};
	template<class T>
	struct list_iterator
	{
		typedef list_node<T> Node;
		typedef list_iterator<T> Self;
		Node* _node;
		list_iterator(Node* node)
			:_node(node)
		{}
		bool operator!=(const Self& s)
		{
			return _node != s._node;
		}
		const T& operator*()
		{
			return _node->_data;
		}
		Self& operator++()
		{
			_node = _node->_next;
			return *this;
		}
		
	};
	template<class T>
	class list
	{
		typedef list_node<T> Node;
	public:
		typedef list_iterator<T> iterator;
		iterator begin()
		{
			return _head->_next;
		}
		iterator end()
		{
			return _head;
		}
		list()
		{
			_head = new Node;
			_head->_next = _head;
			_head->_prev = _head;
			_size = 0;
		}
		size_t size()
		{
			return _size;
		}
		void push_back(const T& x)
		{
			insert(end(), x);
		}
		void push_front(const T& x)
		{
			insert(begin(), x);
		}
		void insert(iterator pos, const T& x)
		{
			Node* cur = pos._node;
			Node* prev = pos._node->_prev;
			Node* newnode = new Node(x);
			//prev newnode cur
			newnode->_next = cur;
			cur->_prev = newnode;
			prev->_next = newnode;
			newnode->_prev = prev;
			++_size;
		}
		void erase(iterator pos)
		{
			assert(pos != end());
			Node* prev = pos._node->_prev;
			Node* next = pos._node->_next;
			prev->_next = next;
			next->_prev = prev;
			delete pos._node;
			--_size;
		}
		void pop_back()
		{
			erase(_head->_prev);
		}
		void pop_front()
		{
			erase(begin());
		}
		bool empty()
		{
			return _size==0;
		}
	private:
		Node* _head;
		size_t _size;
	};
}

我们下期见!!!


http://www.kler.cn/a/509897.html

相关文章:

  • 企业级NoSQL数据库Redis
  • 计算机网络 (41)文件传送协议
  • 4.Spring AI Prompt:与大模型进行有效沟通
  • 电脑风扇声音大怎么办? 原因及解决方法
  • Titans 架构中的记忆整合:Memory as a Context;Gated Memory;Memory as a Layer
  • 国产编辑器EverEdit - 复制为RTF
  • KAGGLE竞赛实战2-捷信金融违约预测竞赛-part2-用lightgbm建立baseline
  • pnpm介绍
  • Java进程内缓存介绍
  • 部署启动nacos报错No DataSource set 及master-db not found
  • 智能学习平台系统设计与实现(代码+数据库+LW)
  • 如何用AI优化自动化回归测试
  • 基于 Android 的个人健康管理 APP 设计与实现
  • Linux探秘坊-------3.开发工具详解(1)
  • 物联网网关Web服务器--Boa服务器移植与测试
  • 某国际大型超市电商销售数据分析和可视化
  • Vue进阶之旅:组件通信与高级用法深度剖析(组件通信进阶用法)
  • 大华C++开发面试题及参考答案
  • opencv对直方图的计算和绘制
  • 网络安全行业岗位职责
  • SSM旅游信息管理系统
  • ros 机器人地图转化为gis地图
  • DNS未响应服务问题的解决(电脑连着网但浏览器访问不了网页)
  • C#高级:通过 Assembly 类加载 DLL 和直接引用DLL的方法大全
  • Chromium 132 编译指南 Linux 篇 - 同步第三方库以及 Hooks(六)
  • Python:两数之和