【从浅到深的算法技巧】链表 补

3.8 队列的实现

基于链表数据结构实现Queue API也很简单,如下面算法所述。它将队列表示为一条从最早插入的元索到最近插入的元素的链表,实例变量first指向队列的开头,实例变量last指向队列的结尾。这样,要将一个元素 入列( enqueue(),我们就将它添加到表尾(但是在链表为空时需要将first和last都指向新结点);要将一个元素出列( dequeue(),我们就删除表头的结点(代码和Stack的pop()方法相同,只是当链表为空时需要更新last的值)。size()和isEmpty()方法的实现和Stack相同。和Stack一样,Queue 的实现也使用了泛型参数Item。Queue 的实现使用的数据结构和Stack相同一链表, 但它实现了不同的添加和删除元素的算法,这也是用例所看到的后进先出和先进后出的区别所在。和刚才一样,我们用链表达到了最优设计目标:它可以处理任意类型的数据:所需的空间总是和集合的大小成正比,操作所需的时间总是和集合的大小无关。

Queue的测试用例
public static void main(String[] args){// 创建一个队列并操作字符事入列成出列Queue<String> q = new Queue<String>();while (!StdIn.isEmpty()){String item = StdIn.readString();if(! item.equals("..."))  q. dequeue(item);else if (!q.isEmpty())    Std0ut.print(q. dequeue() +”");}StdOut.println("("+ q.size() + " left on queue)");}
public class Queue<Item> implenents Iterable<Item>{private Node first; //指向最早添加的结点的链接private Node last; //指向最近添加的结点的链接private int N;//队列中的元素数量private class Node{//定义了结点的嵌套类Item item;Node next;}public boolean isEmpty() { return first == null; } //或: N==0public int size() { return N; } public void enqueue(Item item){//向表尾添加元素Node oldlast = last;last = new Node():last.item = item;if (isEmpty()) first = last;else                oldlast.next = last;}public Item dequeue(){//从表头删除元素Item item=first.item;if (isEmpty()) last = null;return item;}}

这份泛型的Queue实现的基础是链表数据结构。它可以用于创建任意数据类型的队列。

在结构化存储数据集时,链表是数组的一种重要的替代方式。在现代编程语言中,安全指针、自动垃圾回收和抽象数据类型的使用使我们能够将链表处理的代码封装在若干个类中。

3.9 背包的实现

用链表数据结构实现我们的Bag API只需要将Stack中的push()改名为add(),并去掉popO的实现即可。对于Stack,链表的访问顺序是后进先出;对于Queue,链表的访问顺序是先进先出;对于Bag,它正好也是后进先出的顺序,但顺序在这里并不重要。要在集合数据类型中实现迭代,第一步就是要添加下面这行代码,这样我们的代码才能引用Java的Iterator接口:

import java. util.Iterator;

第二步是在类的声明中添加这行代码,它保证了类必然会提供一个iterator()方法:

implements Iterable<Item>

iterator()方法本身只是简单地从实现了lterator 接口的类中返回一个对象:

public Iterator<Item iterator>(){return new ListIterator(); }

这段代码保证了类必然会实现方法hasNext()、next(和remove()供用例的foreach语法使用。要实现这些方法,算法中的嵌套类ListIterator维护了一个实例变量current来记录链表的当前结点。hasNext()方法会检测current是否为null, next()方法会保存当前元素的引用,将current变量指向链表中的下个结点并返回所保存的引用。

import java.util.Iterator;public class Bag<Item> implements Iterator(){private Node first; //链表的首结点private class Node}public void add(Item item){//和Stack的push()方法完全相同first = new Node();first.next = oldfirst;first.item=item;first.next=oldfirst;}public Iterator<Item iterator>(){return new ListIterator();}private class ListIterator implements Iterator<Item>{private Node current =first;public boolean hashNext(){return current != null;}public void remove() { }public Item next(){current = current.next;return item;}}

这份Bag的实现维护了一条链表, 用于保存所有通过add()添加的元素。size() 和isEmpty()方!法的代码和Stack中的完全相同。迭代器会遍历链表并将当前结点保存在current变量中。Stack和Queue的链表访问顺序分别是后进先出和先进先出而已。

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

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

相关文章

React类组件中super()和super(props)有什么区别?

React中super&#xff08;&#xff09;和super&#xff08;props&#xff09;有什么区别&#xff1f; 回答思路&#xff1a;说说ES6类的继承-->说说类组件的继承-->总结区别ES6类的继承类组件的继承总结区别 回答思路&#xff1a;说说ES6类的继承–>说说类组件的继承–…

【操作系统】实验三 编译 Linux 内核

&#x1f57a;作者&#xff1a; 主页 我的专栏C语言从0到1探秘C数据结构从0到1探秘Linux &#x1f618;欢迎关注&#xff1a;&#x1f44d;点赞&#x1f64c;收藏✍️留言 &#x1f3c7;码字不易&#xff0c;你的&#x1f44d;点赞&#x1f64c;收藏❤️关注对我真的很重要&…

基于springboot+vue的在线商城系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…

git的使用(idea中)

文章目录 Git分布式版本控制工具1、目标2、概述2.1、开发中的实际场景2.2、版本控制器的方式2.3、SVM2.4、Git2.5、Git工作流程 3、Git安装与常用命令3.1、Git环境配置3.1.1 下载与安装3.1.2基本配置3.1.3为常用指令配置别名(可选)3.1.4解决GitBash乱码问题 3.2、获取本地仓库3…

Ubuntu20.04安装cuda12.11

显卡驱动 首先就是安装显卡驱动&#xff0c;我是双3090&#xff0c;不知道为什么&#xff0c;官网死活安不上&#xff0c;最后从软件更新那里直接安装上了&#xff0c;绷不住了 cuda 首先从官网下载runfile文件 安装的时候记得驱动和Kernel Objects 和 nvidia-fs不选 然后…

第11次修改了可删除可持久保存的前端html备忘录:将样式分离,可以自由秒添加秒删除样式

第11次修改了可删除可持久保存的前端html备忘录&#xff1a;将样式分离&#xff0c;可以自由秒添加秒删除样式 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"…

蜜雪冰城、古茗组团上市,打响新一轮供应链攻防战

2024年首个工作日&#xff0c;新式茶饮品牌古茗、蜜雪冰城不约而同地向港交所提交上市申请书&#xff0c;“上市”替代“万店”成为新式茶饮行业的热词。 1月2日&#xff0c;古茗控股有限公司向港交所提交上市申请书&#xff0c;联席保荐人为高盛和瑞银集团&#xff0c;计划部…

达梦数据库Windows安装教程:从准备到完成

目录 博客前言&#xff1a; 一.达梦数据库安装前准备 1.下载 2.进行解压 装载 二.正式安装 选择语言与时区 安装向导 许可证协议 验证 Key 文件 选择安装组件 选择安装目录 安装前小结 数据库安装 数据库安装完成 三.配置实例 选择操作方式 创建数据库模板 选…

理德外汇:日本央行下调2024财年通胀预期,日本股汇上演“过山车”

2024年首次货币政策会议&#xff0c;日本央行依旧“按兵不动”&#xff0c;维持收益率曲线控制&#xff08;YCC&#xff09;及负利率政策不变&#xff0c;基本符合市场预期。与此同时&#xff0c;日本央行下调了2024财年核心CPI预期&#xff0c;以及2023年GDP预期。日本股汇上演…

Mysql插入带有引号的字符串数据

在MySQL中处理带有引号的字符串数据&#xff1a;深入探讨与最佳实践 在MySQL数据库操作中&#xff0c;插入带有引号的字符串数据是一个常见任务。然而&#xff0c;由于引号在SQL中的特殊作用&#xff0c;处理不当可能导致数据插入失败或产生非预期结果。本文将深入探讨如何在M…

【操作系统】实验四 增加Linux系统调用

&#x1f57a;作者&#xff1a; 主页 我的专栏C语言从0到1探秘C数据结构从0到1探秘Linux &#x1f618;欢迎关注&#xff1a;&#x1f44d;点赞&#x1f64c;收藏✍️留言 &#x1f3c7;码字不易&#xff0c;你的&#x1f44d;点赞&#x1f64c;收藏❤️关注对我真的很重要&…

低噪声放大器LNA 之 噪声系数

​ 一、噪声系数的定义 在定义噪声系数之前&#xff0c;先看一个放大器输入输出端信噪比&#xff08;信号功率与噪声功率之比&#xff0c;写作SNR&#xff09; 对比图&#xff1a; ​​从上图可用看出&#xff0c;从输入端到输出端&#xff0c;信号和噪声功率都得到了放大&…

【每日一题】2865. 美丽塔 I-2024.1.24

题目: 2865. 美丽塔 I 给你一个长度为 n 下标从 0 开始的整数数组 maxHeights 。 你的任务是在坐标轴上建 n 座塔。第 i 座塔的下标为 i ,高度为 heights[i] 。 如果以下条件满足,我们称这些塔是 美丽 的: 1 <= heights[i] <= maxHeights[i]heights 是一个 山脉 …

#Uniapp:onPullDownRefresh下拉刷新 和阻止stopPullDownRefresh

页面下拉刷新周期 局部配置页面下拉刷新 "pages": [ //pages数组中第一项表示应用启动页&#xff0c;参考&#xff1a;https://uniapp.dcloud.io/collocation/pages{"path": "pages/message/message","style": {"navigationBar…

解析 linux 进程 pid 0, pid 1, pid 2 关系及启动过程

三个进程的关系 Linux 中有pid 0, pid 1 和 pid 2 三个特殊的进程。 pid 0&#xff0c;即 “swapper” 进程&#xff0c;是 pid 1 和 pid 2 的父进程。 pid 1&#xff0c;即 “init” 进程&#xff0c;所有用户空间的进程均派生自该进程。 pid 2&#xff0c;即 “kthreadd” 进…

使用 vLLM 部署本地 LLM 指南

目录 vLLM 安装与模型下载离线批量推理OpenAI 兼容服务器 参考资料&#xff1a; vLLM GitHub首页 vLLM 官方文档 vLLM 安装与模型下载 vLLM 安装&#xff1a;直接 pip install 即可 我选取了 OpenChat-3.5-0106 模型&#xff0c;这个模型是由 mistralai/Mistral-7B-v0.1 微…

docker设置代理解决内网pull外网镜像

目录 Docker 配置代理的缘由 通过dockerd配置实现代理 通过container配置实现代理 参考文献 Docker 配置代理的缘由 如何在内网环境内环境内Pull外网registry&#xff0c;或者反过来想要Pull公司Registry镜像&#xff1f;存在上述需求的朋友可以尝试以下方法进行docker代理…

java访问mdb文件隐藏表报错解决办法:user lacks privilege or object not found: MSYSOBJECTS

java访问mdb文件隐藏表报错解决办法&#xff1a; UCAExc:::5.0.1 user lacks privilege or object not found: MSYSOBJECTS 在地址url中添加;sysSchematrue 在sql语句中添加sys.MSysObjects 写法 在地址url中添加;sysSchematrue 在sql语句中添加sys.MSysObjects 写法数据库访…

高校实验室智能管理

运行环境&#xff1a; jdk7tomcat7mysqleclipse 技术&#xff1a; springhibernatestruts2jspjquery 功能介绍&#xff1a; 一套完整的实验室管理系统&#xff0c;系统支持用户的注册登陆&#xff0c;系统分为学生&#xff0c;教师&#xff0c;管理员三个角色&#xff0c;…

[BUG] Authentication Error

前言 给服务器安装了一个todesk&#xff0c;但是远程一直就是&#xff0c;点击用户&#xff0c;进入输入密码界面&#xff0c;还没等输入就自动返回了 解决 服务器是无桌面版本&#xff0c;或者桌面程序死掉了&#xff0c;重新安装就好 sudo apt install xorg sudo apt inst…