STL源码剖析 序列式容器 slist

  • STL l i s t 是个双向链表(double linked lis t) 。SGI STL提供了一个单向链 表 (single linked lis t) , 名 为 slist
  •  s l i s t 和 l i s t 的主要差别在于,前者的迭代器属于单向的Forwardlterotor, 后者的迭代器属于双向的Bidirectional Iterator.为此,s l i s t 的功能自然也就受到许多限制。不过,单向链表所耗用的空间更小,某些操作更快,不失为另一种选择。
  • list使用双向的Bidirectional Iterator可以双向移动
  • slist使用单向的Forwardlterotor只可以单向移动
  • s l i s t 和 l i s t 共同具有的一个相同特色是,它们的插入(insert)、移除 (erase) 、接 合 (splice) 等操作并不会造成原有的迭代器失效(当然啦,指向被 移除元素的那个迭代器,在移除操作发生之后肯定是会失效的)
  • 插入操作会将新元素插入于指定位置之前,而非之后。
  • 然而作为一个单向链表,s lis t没有任何方便的办法可以回头定出前一个位置, 因此它必须从头找起。换句话说,除了 s lis t起点处附近的区域之外,在其它位置 上采用insert或 erase操作函数,都属不智之举。这便是s lis t相较于l i s t 之下的大缺点。为此,s l i s t 特别提供了 insert_after ()和 erase_after ()供灵活运用。
  • 基于同样的(效率)考虑,s l i s t 不提供push_back(),只提供push_front ()。因此s lis t 的元素次序会和元素插入进来的次序相反。list插入元素每次都会在头部执行,因此速度较快,但是插入元素的顺序和list中元素的存储顺序相反。

 

 

 

  •  注意,比较两个Slist迭代器是否等同时(例如我们常在循环中比较某个迭代器是否等同于Slist .end()),
  • 由于 _ slist_iterator 并未对 operator==实 施重载,所以会调用_slist_iterator_base::operator==□ 根据其中之定义, 我们知道,两 个 Slist迭代器是否等同,视 其 一 slist_node_base* node是否等同而定。

 

 

 

 

 

  •  首先依次序把元素9,1,2,3,4插入到s l i s t ,实际结构呈现如图4-26。 接下来搜寻元素1 ,并将新元素99插入进去,如图4-27。
  • 注意,新元素被插入在插入点(元素1 )的前面而不是后面。
  • 接下来搜寻元素3 ,并将该元素移除,如图4-28.

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/446405.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

中科大 计算机网络12 Web和HTTP

Web与HTTP 对象:web页中其实是对象链接 URL:通用资源定位符【任何对象都可以使用URL来唯一标识】 用户名:口令【支持匿名访问,用户名和口令不计】 端口:HTTP:80 FTP:21【使用默认端口号&#x…

STL源码剖析 关联式容器 树 红黑树、二叉搜索树、平衡二叉搜索树

所谓关联式容器,观念上类似关联式数据库(实际上则简单许多):每笔数据(每个元素)都有一个键值(key)和一个实值(value) 2。当元素被插入到关联式 容器中时,容器内部结构(可能是RB-tree,也可能是hash-table)便依照其键 值大小,以某种…

北京大学 软件工程1 软件 软件工程 软件开发 软件工程框架

软件的定义 重新定义软件 新一代信息技术 区块链 创造性思维 软件的特点 软件的种类 支撑软件:VC,PyCharm等 应用软件:QQ,微信 软件工程的起源 软件开发的三个阶段 软件工程概念的提出 软件工程的定义 软件工程将系统化&#…

java学习_Python基础学习教程:从0学爬虫?让爬虫满足你的好奇心

Python基础学习教程:从0学爬虫?让爬虫满足你的好奇心有必要学爬虫吗?我想,这已经是一个不需要讨论的问题了。爬虫,“有用”也“有趣”!这个数据为王的时代,我们要从这个庞大的互联网中来获取到我…

安卓rom制作教程_安卓手机TWRP_Recovery卡刷图文教程 适用于卡刷ROM,TWRP救砖

扫一扫二维码,关注我,解决刷机各种疑难杂症 ROM乐园独家支持最近有很多小伙伴问怎么去卡刷,卡刷的操作是什么,什么是卡刷,小编就仔细来写一下卡刷教程吧,记住,我们所说的卡刷,并不是…

东软 软件工程1 软件危机 软件工程 软件生命周期

软件危机 软件危机产生的原因 消除软件危机的途径: 软件工程历史 软件工程的概念 软件工程项目的基本目标 软件工程的基本原理 软件生命周期 软件工程的中的软件生命周期

iphone全部机型_iPhone 12 销量或创 iPhone 6 以来最高|iphone|郭明錤

iPhone 12 系列目前正在预售中,本周五两款 英寸机型就将正式上市。有不少小伙伴已经成功预购到了首批 iPhone 12,另有一些用户仍在持币观望,等待第三方平台报出更便宜的价格。而从 iPhone 12 的预售情况来看,两款 英寸机型还是相当…

东软 软件工程2 软件开发模型 瀑布模型 原型模型 螺旋模型 统一过程模型RUP 敏捷开发模型

软件开发过程模型 瀑布模型 原型模型 螺旋模型 统一过程模型-RUP 敏捷开发模型 敏捷开发模型:Scrum方法 敏捷开发模型:进行Scrum开发

算法 笔试的时候 如何输入元素?

/* * 长度 3* 数组 1 2 3* 注意&#xff1a;元素之间以空格相隔 */int length 0;std::cin >> length;getchar();std::vector<int>input_vector{};for (int i 0; i < length; i) {int temp 0;std::cin >> temp;input_vector.emplace_back(temp);} 使…

自动点击器一秒200_做PPT还需要找模板?用这招3分钟就能自动排好PPT!

点击上图直达活动详情页&#xff0c;优惠券超 400 元&#xff01;大家好&#xff0c;我是爱挖神器的洁洁。今天我来跟大家聊聊「PPT里的神器」~我们每次做 PPT 的时候&#xff0c;经常面对的一个难题就是&#xff1a;如&#xff01;何&#xff01;排&#xff01;版 ?比如像这样…

东软 软件工程3 软件项目管理 团队组织管理

团队组织管理 团队的概念 项目组的组织原则 项目组的组织方式 软件项目管理过程组

dedecms怎么改php版本_玩转Termux:手把手教你在手机上安装php与nginx!

大家好&#xff0c;这里是 「手机编程」&#xff0c;我是作者&#xff1a;舞剑&#xff0c;记得「关注我」今天是Termux系列第三节&#xff0c;我来讲讲怎么安装 PHP 与 Mysql&#xff0c;然后用 Termux 搭建一个网站。PHP全球有几乎95%的网站都使用 php 需要编写的&#xff0c…

Python学习8 函数 匿名函数 内置函数

转换相关的方法-eval 转换相关的方法-json 函数基本语法大纲 函数概念 示例&#xff1a; 题目&#xff1a; 函数的参数 def f(x,y1,*z,**abc):print(x,y,z,abc,sep"\n")f(1,4,5,3,a1,b2,c3) #1 # 4 # (5, 3) # {a: 1, b: 2, c: 3}易错题&#xff1a; 1&#xff0…

求两个集合的交集

letcode原题 排序双指针 如果两个数组是有序的&#xff0c;则可以使用双指针的方法得到两个数组的交集。首先对两个数组进行排序&#xff0c;然后使用两个指针遍历两个数组。初始时&#xff0c;两个指针分别指向两个数组的头部。每次比较两个指针指向的两个数组中的数字&#…

Python学习7 集合Set

区别 集合的基本使用 如果是空集合&#xff0c;使用set {}是字典 pop:无序&#xff0c;随机删除一个元素 add添加一个元素 remove移除指定元素 update合并&#xff0c;合并在原集合上 union合并到一个新的集合上 clear清空 总结&#xff1a; 集合运算 补集&#xff1a; f…

cad怎么快速算面积_用cad算面积的快捷键方法步骤详细,大朗CAD培训班

在绘图的过程中经常需要查询和计算图形的面积&#xff0c;网上有不少人问这方面的问题。都市领航教育将计算面积的方法和相关命令整理一下&#xff0c;希望对初学者有帮助。 查询图形的面积 我们利用边界或编辑多段线命令生成了多段线和面域&#xff0c;不需要再使用查询面积命…

给定没有重复数字的序列,将其全排列

leetcode题目 void backtrack(vector<vector<int>>& res, vector<int>& output, int first, int len){if (firstlen){res.push_back(output);}for (int i first; i < len; i) {std::swap(output[first],output[i]);backtrack(res,output,first1,…

Java web后端4 会话 Cookie Session

会话 会话&#xff1a;指的是一个客户端&#xff08;浏览器&#xff09;与Web服务器之间连续发生的一系列请求和响应的过程。 客户端和服务器的请求和响应的过程&#xff08;对话双方只要有一方发生变化&#xff0c;都属于不同的会话&#xff09; 超时间隔【距离上一次请求的…

将安全信息应用到以下对象时发生错误 拒绝访问_手机资讯:拒绝「京东金融」事件再次发生|如何避免iPhone 应用私自获取照片...

如今使用IT数码设备的小伙伴们是越来越多了&#xff0c;那么IT数码设备当中是有很多知识的&#xff0c;这些知识很多小伙伴一般都是不知道的&#xff0c;就好比最近就有很多小伙伴们想要知道拒绝「京东金融」事件再次发生|如何避免iPhone 应用私自获取照片&#xff0c;那么既然…