java-队列--黑马

队列

别看这个,没用,还是多刷力扣队列题
定义

队列是以顺序的方式维护一组数据的集合,在一端添加数据,从另一端移除数据。一般来讲,添加的一端称之,而移除一端称为

队列接口定义

// 队列的接口定义
public interface Queue<E> {// 向队尾添加元素// 添加成功,返回true; 添加失败返回 false  boolean offer(E value);// 获取头部元素,并移除元素E poll();// 获取头部元素,不移除E peek();// 判断队列是否为空boolean isEmpty();// 判断队列是否满boolean isFull();
}

实现队列

链表实现

使用单向循环带哨兵链表实现队列
在这里插入图片描述

public class LinkedListQueue<E> implements Queue<E>, Iteable<E> {private static class Node<E> {E value;Node next;public Node(E value, Node<E> next) {this.value = value;this.next = next;}}Node<E> head = new Node(null, null);	// 哨兵头Node<E> tail = head;					// 哨兵尾private int size;private int capacity;public LinkedListQueue(int capacity) {this.capacity = capacity;tail.next = head;}public LinkedListQueue() {tail.next = head;}@Overridepublic boolean offer(E value) {if (isFull()) {return false;}Node<E> added = new Node<>(value, head);tail.next = added;tail = add;size++;return true;}@Ovrridepublic E poll() {if (isEmpty()) {return null;}Node<E> first = head.next;head.next = first.next;if (first == tail) {tail = head;}size--;return first.value;}@Overridepulic E peek() {if (isEmpty()) {return null;}return head.next.value;}@Overridepublic boolean isEmpty() {return head == tail;}@Override public boolean isFull() {return size == capacity;}@Overridepublic Iterator<E> iterator() {return new Iterator<E>() {Node<E> p = head.next;@Overridepublic boolean hasNext() {return p != head;}@Overridepublic E next() {E value = p.value;p = p.next;return value;}}}
}

环形数组实现

方法一
public class ArrayQueue<E> implements Queue<E>, Iterable<E> {private E[] array;private int head = 0;private int tail = 0;public ArrayQueue(int capacity) {array = (E[]) new Object[capacity + 1];}// 添加元素@Overridepublic boolean offer(E value) {// 判断队列是否满if (isFull()) {return false;}array[tail] = value;tail = (tail + 1) % array.length;return true;}// 移除队列头部元素,并返回@Overridepublic E poll() {if (isEmpty()) {return null;}E value = array[head];head = (head + 1) % array.length;return value;}// 获取队列头部元素@Overridepublic E peek() {if(isEmpty()) {return null;}return array[head];}@Overridepublic boolean isEmpty() {return head == tail;}@Overridepublic boolean isFull() {return (tail + 1) % array.length == head;}@Overridepublic Iterator<E> iterator() {return new Iterator<E>() {int p = head;@Overridepublic boolean hasNext() {return p != null;// return (p + 1) $ array.length != head;  是对的吗?}@Overridepublic E next() {E value = array[p];p = (p + 1) % array.length;return value;}}}
}
方法二 – 修改方法一

添加size变量判断队列是否为空或者为满的情况

public class ArrayQueue2<E> implements Queue<E>, Iterable<E> {private E[] array;private int head = 0;private int tail = 0;private int size = 0;public ArrayQueue2(int capacity) {array = (E[]) new Object[capacity + 1];}// 添加元素@Overridepublic boolean offer(E value) {// 判断队列是否满if (isFull()) {return false;}array[tail] = value;tail = (tail + 1) % array.length;size++;return true;}// 移除队列头部元素,并返回@Overridepublic E poll() {if (isEmpty()) {return null;}E value = array[head];head = (head + 1) % array.length;size--;return value;}// 获取队列头部元素@Overridepublic E peek() {if(isEmpty()) {return null;}return array[head];}@Overridepublic boolean isEmpty() {return size == 0;}@Overridepublic boolean isFull() {return size = array.length;}@Overridepublic Iterator<E> iterator() {return new Iterator<E>() {int p = head;int count = 0;@Overridepublic boolean hasNext() {return count < size;}@Overridepublic E next() {E value = array[p];p = (p + 1) % array.length;count++;return value;}}}
}
方法三
public class ArrayQueue3<E> implements Queue<E>, Iterable<E> {private final E[] array;private int head = 0;private int tail = 0;public ArrayQueue(int capacity) {array = (E[]) new Object[capacity];}// 添加元素@Overridepublic boolean offer(E value) {// 判断队列是否满if (isFull()) {return false;}array[tail & array.length] = value;tail = tail + 1;return true;}// 移除队列头部元素,并返回@Overridepublic E poll() {if (isEmpty()) {return null;}E value = array[head % array.length];head = head + 1;return value;}// 获取队列头部元素@Overridepublic E peek() {if(isEmpty()) {return null;}return array[head % array.length];}@Overridepublic boolean isEmpty() {return head == tail;}@Overridepublic boolean isFull() {return tail - head == array.length;}@Overridepublic Iterator<E> iterator() {return new Iterator<E>() {int p = head;@Overridepublic boolean hasNext() {return p != tail;}@Overridepublic E next() {E value = array[p % array.length];p++;return value;}}}
}

改进算法,防止数组越界

  • 前提是数组容量必须是2的n次方
public class ArrayQueue3<E> implements Queue<E>, Iterable<E> {private final E[] array;private int head = 0;private int tail = 0;public ArrayQueue(int capacity) {array = (E[]) new Object[capacity];}// 添加元素@Overridepublic boolean offer(E value) {// 判断队列是否满if (isFull()) {return false;}array[tail & array.length - 1] = value;tail = tail + 1;return true;}// 移除队列头部元素,并返回@Overridepublic E poll() {if (isEmpty()) {return null;}E value = array[head % array.length - 1];head = head + 1;return value;}// 获取队列头部元素@Overridepublic E peek() {if(isEmpty()) {return null;}return array[head % array.length - 1];}@Overridepublic boolean isEmpty() {return head == tail;}@Overridepublic boolean isFull() {return tail - head == array.length;}@Overridepublic Iterator<E> iterator() {return new Iterator<E>() {int p = head;@Overridepublic boolean hasNext() {return p != tail;}@Overridepublic E next() {E value = array[p % array.length - 1];p++;return value;}}}
}

二叉树层序遍历

使用队列

public class Leetcode102{public static void main(String[] args) {TreeNode root = new TreeNode(new TreeNode(new TreeNode(4), 2, new TreeNode(5)),1,new TreeNode(new TreeNode(6), 3, new TreeNode(7)));LinkedListQueue<TreeNode> queue = new LinkedListQueue<>();queue.offer(root);while (!queue.isEmpty()) {TreeNode n = queue.poll();System.out.println(n);if (n.left != null) {queue.offer(n.left);}if (n.right != null) {queue.offer(n.right);}}}
}

在此基础上实现分层效果
在这里插入图片描述

public class Leetcode102{public static void main(String[] args) {TreeNode root = new TreeNode(new TreeNode(new TreeNode(4), 2, new TreeNode(5)),1,new TreeNode(new TreeNode(6), 3, new TreeNode(7)));LinkedListQueue<TreeNode> queue = new LinkedListQueue<>();queue.offer(root);int c1 = 1;while (!queue.isEmpty()) {int c2 = 0;for(int i = 0; i < c1; i++) {TreeNode n = queue.poll();System.out.print(n + " ");if (n.left != null) {queue.offer(n.left);c2++;}if (n.right != null) {queue.offer(n.right);c2++;}}System.out.println();c1 = c2;}}
}

力扣102题的实现

public class Leetcode102{public List<List<Integer>> levelOrder(TreeNode root) {List<List<Integer>> res = new ArrayList<>();if (root == null) {return res;}LinkedList<TreeNode> queue = new LinkedList<>();queue.offer(root);int c1 = 1;while (!queue.isEmpty()) {int c2 = 0;List<Integer> list = new ArrayList<>();for(int i = 0; i < c1; i++) {TreeNode n = queue.poll();list.add(n.val);if (n.left != null) {queue.offer(n.left);c2++;}if (n.right != null) {queue.offer(n.right);c2++;}}res.add(list);c1 = c2;}return res;}
}
        List<Integer> list = new ArrayList<>();for(int i = 0; i < c1; i++) {TreeNode n = queue.poll();list.add(n.val);if (n.left != null) {queue.offer(n.left);c2++;}if (n.right != null) {queue.offer(n.right);c2++;}}res.add(list);c1 = c2;}return res;
}

}


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

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

相关文章

Linux——驱动——杂项设备

一、杂项设备驱动 1、概念 杂项设备&#xff08;Miscellaneous Devices&#xff09;在Linux内核中是一种特殊的设备类型&#xff0c;用于表示那些不适合被归类为其他标准设备类型的设备。这些设备通常具有不规则的特性和非标准的通信协议或接口。 2、操作流程 杂项设备注册过…

中国数据库的崛起:从本土化挑战到全球化机遇

引言 谈起中国的崛起&#xff0c;大家第一反应可能是“中国制造”“高铁奇迹”“电商帝国”&#xff0c;但今天我们要聊的&#xff0c;是一个比这些还要神秘的存在——中国的数据库技术。或许你平时并不会经常关注它&#xff0c;但这个隐身在你手机、电脑、服务器背后的无形力…

002、架构_概览

GoldenDB 主要由管理节点、计算节点、数据节点、全局事务节点等模块组成&#xff0c;各个节点无需共享任何资源&#xff0c;均为独立自治的通用计算机节点&#xff0c;之间通过高速互联的 网络通讯&#xff0c;从而完成对应用数据请求的快速处理和响应。 管理节点在数据库中主要…

如何在寂静中用电脑找回失踪的手机?远程控制了解一下

经过一番努力&#xff0c;我终于成功地将孩子哄睡了。夜深人静&#xff0c;好不容易有了一点自己的时间&#xff0c;就想刷手机放松放松&#xff0c;顺便看看有没有重要信息。但刚才专心哄孩子去了&#xff0c;一时就忘记哄孩子之前&#xff0c;顺手把手机放哪里去了。 但找过手…

种树问题——CSP-J1真题讲解

【题目】 小明在某一天中依次有七个空闲时间段&#xff0c;他想要选出至少一个空闲时间段来练习唱歌&#xff0c;但他希望任意两个练习的时间段之间都有至少两个空闲的时间段让他休息。则小明一共有( ) 种选择时间段的方案 A. 31 B. 18 C. 21 D. 33 【答案】 B 【解析…

Vue.js学习笔记(七)使用sortablejs或el-table-draggable拖拽ElementUI的el-table表格组件

文章目录 前言一、el-table-draggable是什么&#xff1f;二、使用步骤1.安装使用2.sortablejs 总结 前言 记录 el-table-draggable 插件使用方法。 一、el-table-draggable是什么&#xff1f; el-table-draggable的存在就是为了让vue-draggable支持element-ui中的el-table组件…

卸载nomachine

网上的方法:提示找不到命令 我的方法: step1. 终端输入 sudo find / -name nxserver 2>/dev/null确认 NoMachine 的实际安装路径。你可以使用 find 命令在系统中查找 nxserver 脚本的位置。 找到路径后,你可以使用该路径来卸载 NoMachine。 如下图,紫色框中是我的路径…

Android - lock/unlock bootloader

在执行 adb remount 时高版本经常会提示失败 此时就需要对设备的进行解锁操作。记录两个部分&#xff0c;Google解锁和展锐解锁。 目录 一、Google解锁 二、展锐解锁 三、补充跳过按键检测的方案 一、Google解锁 官网介绍的unlock方法如下&#xff1a;锁定/解锁引导加载程序…

RK3588 技术分享 | 在Android系统中使用NPU实现Yolov5分类检测-迅为电子

随着人工智能和大数据时代的到来&#xff0c;传统嵌入式处理器中的CPU和GPU逐渐无法满足日益增长的深度学习需求。为了应对这一挑战&#xff0c;在一些高端处理器中&#xff0c;NPU&#xff08;神经网络处理单元&#xff09;也被集成到了处理器里。NPU的出现不仅减轻了CPU和GPU…

Linux基础环境开发工具gcc/g++ make/Makefile git

1.Linux编译器-gcc/g使用 1. 预处理&#xff08;进行宏替换) 预处理功能主要包括宏定义,文件包含,条件编译,去注释等。 预处理指令是以#号开头的代码行。 实例: gcc –E hello.c –o hello.i 选项“-E”,该选项的作用是让 gcc 在预处理结束后停止编译过程。 选项“-o”是指目标…

【Java数据结构】---二叉树OJ

乐观学习&#xff0c;乐观生活&#xff0c;才能不断前进啊&#xff01;&#xff01;&#xff01; 我的主页&#xff1a;optimistic_chen 我的专栏&#xff1a;c语言 &#xff0c;Java 欢迎大家访问~ 创作不易&#xff0c;大佬们点赞鼓励下吧~ 文章目录 相同的树另一颗树的子树翻…

linux死锁问题和cpu使用率过高问题排查

1、问题共同点 死锁问题和cpu使用率过高都是需要我们找出对应的问题线程。 死锁问题需要我们找出哪两个线程出现了死锁情况。 cpu使用率过高需要我们找出哪个或哪些线程占用了大量的cpu。 2、命令排查 2.1、查看机器上的Java进程 jcmd或 jps2.2、查看对应Java进程的线程级别…

五子棋理解C++思想

双人五子棋项目目录&#xff1a; class Game { public:Game();void init();bool waitPlayerPutChess(Player* player, int& oldi, int& oldj);void draw();void play();bool isOver(int playerId);public:int whoWin -1; // 谁赢了&#xff08;0&#xff1a;白棋&a…

科创中心“核”动力|趋动科技:AI算力界的领跑者

近日&#xff0c;趋动科技与深信服正式推出联合解决方案。联合解决方案将深信服EDS的高性能存储与趋动科技OrionX AI算力资源池化软件、以及GeminiAI训练平台有机结合&#xff0c;整合存力与算力资源的同时&#xff0c;帮助用户建好AI平台、管好AI资源、用好AI服务。 双方已完成…

Web3链上聚合器声呐已全球上线,开启区块链数据洞察新时代

在全球区块链技术高速发展的浪潮中&#xff0c;在创新发展理念的驱动下&#xff0c;区块链领域的工具类应用备受资本青睐。 2024年8月20日&#xff0c;由生纳&#xff08;香港&#xff09;国际集团倾力打造的一款链上应用工具——“声呐链上聚合器”&#xff0c;即“声呐链上数…

Facebook的区块链战略:如何在社交媒体中实现去中心化

随着区块链技术的发展&#xff0c;Facebook&#xff08;现Meta&#xff09;正积极探索如何将这一技术整合进其社交平台中&#xff0c;以提升用户体验和数据安全。区块链技术以去中心化、透明性和不可篡改性为特点&#xff0c;为社交媒体带来了新的可能性。本文将探讨Facebook在…

嵌入式和单片机有什么区别?

目录 &#xff08;1&#xff09;什么是嵌入式&#xff1f; &#xff08;2&#xff09;什么是单片机&#xff1f; &#xff08;3&#xff09;嵌入式和单片机的共同点 &#xff08;4&#xff09;嵌入式和单片机的区别 &#xff08;1&#xff09;什么是嵌入式&#xff1f; 关…

Linux云计算 |【第二阶段】SECURITY-DAY1

主要内容&#xff1a; 监控基础&#xff08;系统监控命令、监控软件&#xff09;、Zabbix监控服务端部署、Zabbix监控客户端部署、创建监控主机、调用监控模板、自定义key、创建模板、应用集、监控项、绑定模板&#xff1b; 一、监控概述 1&#xff09;监控的目的 ① 实时报…

【Hot100】LeetCode—114. 二叉树展开为链表

目录 1- 思路技巧——借助指针 2- 实现⭐114. 二叉树展开为链表——题解思路 3- ACM 实现 原题连接&#xff1a;114. 二叉树展开为链表 1- 思路 技巧——借助指针 思路&#xff1a;通过 ① 将左子树的右下结点的 .next ——> 拼接到当前节点的右子树上。 构造 cur 指针&a…

数据结构【链试结构二叉树】

&#x1f31f;个人主页&#xff1a;落叶 目录 ​编辑 实现链式结构⼆叉树 前中后序遍历&#xff1a; 遍历规则 代码实现 前序遍历&#xff1a; 中序遍历&#xff1a; 后序遍历&#xff1a; 图解遍历&#xff1a; 函数递归栈帧图&#xff1a; 结点个数以及高度等 【⼆…