java数据结构与算法:双链表 LinkedList

双链表 LinkedList

实现代码

package com.lhs;public class LinkedList<E> implements List<E>{// 定义链表长度private int size;// 定义头节点private Node<E> first;// 定义尾节点private Node<E> last;// 内部类,定义节点public static class Node<E>{// 定义节点数据E data;// 定义下一个节点Node<E> next;// 定义前一个节点Node<E> pre;// 构造函数,用于创建新的节点Node(E data,Node<E> next,Node<E> pre){this.data = data;this.next = next;this.pre = pre;}}// 重写size方法,返回链表长度@Overridepublic int size() {return size;}// 重写isEmpty方法,判断链表是否为空@Overridepublic boolean isEmpty() {return size == 0;}// 重写contains方法,判断链表是否包含某元素@Overridepublic boolean contains(Object o) {return IndexOf(o) >= 0;}// 重写IndexOf方法,返回某元素在链表中的位置public int IndexOf(Object o){Node<E> node = first;if (o == null){for (int i = 0; i < size; i++) {if (node.data == null){return i;}node = node.next;}return -1;}else{for (int i = 0; i < size; i++) {if (o.equals(node.data)){return i;}node = node.next;}return -1;}}// 重写add方法,向链表末尾添加元素@Overridepublic boolean add(E e) {if (size == 0){Node<E> node = new Node<>(e, null, null);first = node;last = node;}else{Node<E> l = last;Node<E> node = new Node<>(e, null, l);l.next = node;last = node;}size++;return true;}// 重写get方法,返回链表中指定位置的元素@Overridepublic E get(int index) {if(index >= size){throw new IndexOutOfBoundsException(index + " out of bound");}Node<E> node;if(index > (size >> 1)){node = last;for(int i = 0 ; i<size - index - 1;i++){node = node.pre;}}else{node = first;for (int i = 0; i < size - index - 1; i++) {node = node.next;}}return node.data;}// 重写set方法,替换链表中指定位置的元素@Overridepublic E set(int index, E e) {if(index >= size){throw new IndexOutOfBoundsException(index + " out of bound");}E oldVal;Node<E> node;if(index > (size >> 1)){node = last;for(int i = 0 ; i<size - index - 1;i++){node = node.pre;}}else{node = first;for (int i = 0; i < size - index - 1; i++) {node = node.next;}}oldVal = node.data;node .data = e;return oldVal;}// 重写remove方法,移除链表中指定位置的元素@Overridepublic E remove(int index) {if(index >= size){throw new IndexOutOfBoundsException(index + " out of bound");}Node<E> node;if(index > (size >> 1)){node = last;for(int i = 0 ; i<size - index - 1;i++){node = node.pre;}}else{node = first;for (int i = 0; i < size - index - 1; i++) {node = node.next;}}E oldVal = node.data;Node<E> n = node.next;Node<E> p = node.pre;if(p != null){p.next = n;}else{first = n;}if(n != null){n.pre = p;}else{last = p;}size--;return oldVal;}// 重写addFirst方法,向链表头部添加元素@Overridepublic void addFirst(E e) {Node<E> f = first;Node<E> node = new Node<>(e, null, f);f.pre = node;first = node;size++;}// 重写addLast方法,向链表尾部添加元素@Overridepublic void addLast(E e) {add(e);}// 重写removeFirst方法,移除链表头部元素@Overridepublic E removeFirst() {return remove(0);}// 重写removeLast方法,移除链表尾部元素@Overridepublic E removeLast() {return remove(size-1);}
}

测试代码

/*** Welcome to https://waylau.com*/
package com.lhs;import org.junit.Test;import java.util.LinkedList;
import java.util.List;import static junit.framework.TestCase.*;
import static org.junit.Assert.assertThrows;/*** LinkedList Test.* * @since 1.0.0 2020年5月4日* @author <a href="https://waylau.com">Way Lau</a>*/
public class LinkedListTests {@Testpublic void testSize() {// 实例化LinkedListList<String> list = new LinkedList<String>();assertTrue(list.size() == 0);list.add("Java");assertTrue(list.size() == 1);}@Testpublic void testIsEmpty() {// 实例化LinkedListList<String> list = new LinkedList<String>();assertTrue(list.isEmpty());list.add("Java");assertFalse(list.isEmpty());}@Testpublic void testContains() {// 实例化LinkedListList<String> list = new LinkedList<String>();list.add("Java");list.add("C++");list.add("C");list.add("Python");list.add("TypeScript");// 判断存在assertTrue(list.contains("Java"));// 判断不存在assertFalse(list.contains("Java++"));}@Testpublic void testAdd() {// 实例化LinkedListList<Integer> list = new LinkedList<Integer>();list.add(1);list.add(2);list.add(3);list.add(4);list.add(5);assertFalse(list.isEmpty());}@Testpublic void testGet() {// 实例化LinkedListList<String> list = new LinkedList<String>();list.add("Java");list.add("C++");list.add("C");// 判断存在assertEquals("C++", list.get(1));// 判断不存在int index = 6;Throwable excpetion = assertThrows(IndexOutOfBoundsException.class, () -> {list.get(index);// 抛异常});assertNotNull(excpetion.getMessage());}@Testpublic void testSet() {// 实例化LinkedListList<String> list = new LinkedList<String>();list.add("Java");list.add("C++");list.add("C");// 判断存在assertEquals("C", list.set(2, "Python"));// 判断不存在int index = 6;Throwable excpetion = assertThrows(IndexOutOfBoundsException.class, () -> {list.set(index, "Python");// 抛异常});assertNotNull(excpetion.getMessage());}@Testpublic void testRemove() {// 实例化LinkedListList<String> list = new LinkedList<String>();list.add("Java");list.add("C++");list.add("C");// 判断存在assertEquals("C", list.remove(2));assertEquals("C++", list.remove(1));assertEquals("Java", list.get(0));// 判断不存在int index = 6;Throwable excpetion = assertThrows(IndexOutOfBoundsException.class, () -> {list.remove(index); // 抛异常});assertNotNull(excpetion.getMessage());}@Testpublic void testAddFirst() {// 实例化LinkedListLinkedList<String> list = new LinkedList<String>();list.addFirst("Java");list.addFirst("C++");list.addFirst("C");// 判断存在assertEquals("C", list.get(0));assertEquals("C++", list.get(1));assertEquals("Java", list.get(2));}@Testpublic void testAddLast() {// 实例化LinkedListLinkedList<String> list = new LinkedList<String>();list.addLast("Java");list.addLast("C++");list.addLast("C");// 判断存在assertEquals("Java", list.get(0));assertEquals("C++", list.get(1));assertEquals("C", list.get(2));}@Testpublic void testRemoveFirst() {// 实例化LinkedListLinkedList<String> list = new LinkedList<String>();list.add("Java");list.add("C++");list.add("C");// 判断存在assertEquals("Java", list.removeFirst());assertEquals("C++", list.removeFirst());assertEquals("C", list.removeFirst());}@Testpublic void testRemoveLast() {// 实例化LinkedListLinkedList<String> list = new LinkedList<String>();list.add("Java");list.add("C++");list.add("C");// 判断存在assertEquals("C", list.removeLast());assertEquals("C++", list.removeLast());assertEquals("Java", list.removeLast());}}

在这里插入图片描述

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

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

相关文章

RK3568平台 温度传感器芯片SD5075

一.SD5075芯片简介 SD5075 是一款高准确度温度传感器芯片内含高精度测温 ADC&#xff0c;在-40C ~100C 范围内典型误差小于0.5C&#xff0c;在-55C~125C 范围内典型误差小于士1.0C。通过两线 IC/SMBus接口可以很方便与其他设备建立通信。设置 A2~A0 的地址线&#xff0c;可支持…

网络配置以及命令详解

传统linux中,网络接口为eth0,eth1,eth2,..... RHEL 7以上版本默认命名是基于分配上的固定名称,ens33 接口类型: en:以太网有线接口 wl:无线局域网接口 ww:无线广域网 dmesg:显示开机信息 适配器类型: s:热插拔插槽 o:板载 p:pci类型 ifconfig ens160(命令行配置,临时生效):查…

算法通关村第十五关—海量数据场景下的热门算法题(白银)

海量数据场景下的热门算法题 一、从40个亿中产生一个不存在的整数 题目要求&#xff1a;给定一个输入文件&#xff0c;包含40亿个非负整数&#xff0c;请设计一个算法&#xff0c;产生一个不存在该文件中的整数&#xff0c;假设你有1GB的内存来完成这项任务。 进阶&#xff1a…

玩转 openEuler (一)-- 系统安装

简介 openEuler 是一款开源操作系统。当前 openEuler 内核源于Linux&#xff0c;支持鲲鹏及其它多种处理器&#xff0c;能够充分释放计算芯片的潜能&#xff0c;是由全球开源贡献者构建的高效、稳定、安全的开源操作系统&#xff0c;适用于数据库、大数据、云计算、人工智能等…

电子电器架构车载软件 —— 集中化架构软件开发

电子电器架构车载软件 —— 集中化架构软件开发 我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师&#xff1a; 屏蔽力是信息过载时代一个人的特殊竞争力&#xff0c;任…

Failed to save password Error code: -34018

1. 卸载navicat 2.打开终端&#xff1a;执行下列命令 sudo rm -Rf /Applications/Navicat\ Premium.app sudo rm -Rf /private/var/db/BootCaches/CB6F12B3-2C14-461E-B5A7-A8621B7FF130/app.com.prect.NavicatPremium.playlist sudo rm -Rf ~/Library/Caches/com.apple.help…

汽车ECU的虚拟化技术初探(四)--U2A内存管理

目录 1.内存管理概述 2. 内存保护功能 2.1 SPID 2.2 Slave Guard 3.小结 1.内存管理概述 为了讲清楚U2A 在各种运行模式、特权模式下的区别&#xff0c;其实首先应该搞清楚不同模式下可以操作的寄存器有哪些。 但是看到这个寄存器模型就头大。 再加上之前没有研究过G4MH…

文件操作(二)

͟͟͞͞&#x1f3c0;前言上一篇我们加们讲了什么是文件&#xff0c;为什么使用文件&#xff0c;以及流的概念。我们继续接上一篇来继续讲解我们的文件操作&#xff0c;这一篇将会详细的讲如何对文件进行读写。 目录 &#x1f680;一.文件的顺序读写 1.fgetc和fputc 2.fget…

【ROS2简单例程】基于python的发布订阅实现

1、自定义消息类型Student 1.1 创建base_interfaces_demo包 1.2 创建Student.msg文件 string name int32 age float64 height 1.2 在cmakeLists.txt中增加如下语句 #增加自定义消息类型的依赖 find_package(rosidl_default_generators REQUIRED) # 为接口文件生成源代码 ro…

Shell中cp和mv命令说明

在Shell&#xff08;如Bash&#xff09;中&#xff0c;cp 和 mv 是两个常用的命令&#xff0c;用于处理文件和目录。它们的用法和作用如下&#xff1a; cp 命令 作用&#xff1a;cp&#xff08;copy的缩写&#xff09;用于复制文件或目录。基本用法&#xff1a;cp [选项] 源文…

【OJ】环形链表

目录 1. 环形链表||&#xff08;142&#xff09;1.1 题目描述1.2 题目分析1.3 代码 2. 环形链表&#xff08;141&#xff09;2.1 题目描述2.2 题目分析2.3 代码 1. 环形链表||&#xff08;142&#xff09; 1.1 题目描述 1.2 题目分析 带环链表&#xff1a;尾节点的next指向链…

ROS OpenCV ROI

在图像处理和计算机视觉领域&#xff0c;ROI&#xff08;Region of Interest&#xff09;是一个核心概念&#xff0c;它指的是从原始图像中定义出的特定区域&#xff0c;该区域对于后续的分析、处理或操作具有特别的意义。 ROI的选择通常基于应用需求&#xff0c;例如目标检测…

【Rust日报】Xilem 项目在 2024 年的计划

Xilem 项目在 2024 年的计划 2024 年&#xff0c;Xilem 项目备受关注。Google Fonts 将资助四位开源贡献者&#xff1a;Aaron Muir Hamilton、Daniel McNab、Matt Campbell 和 Olivier Faure&#xff0c;他们将主导项目的不同方面。Aaron 将专注于文本布局和 Android 集成&…

Python异步网络编程库之twisted 详解

概要 Python twisted 是一个强大的异步网络编程框架&#xff0c;它允许开发者轻松构建高性能的网络应用和协议。无论是构建网络服务器、客户端、聊天应用还是实时通信工具&#xff0c;twisted 都提供了丰富的工具和组件。本文将深入探讨 twisted 的基本概念、安装方法以及详细…

Python常用日期函数和日期处理方法

Python常用日期函数和日期处理方法 Python常用的日期处理函数使用案例, 和一些简单的日期处理方法(持续更新) 1. 使用time获取当前的日期和时间 import time from time import gmtime, strftimet time.localtime() print (t) # time.struct_time(tm_year2024, tm_mon1, tm…

sql | 学生参加各科考试次数

学生表: Students------------------------ | Column Name | Type | ------------------------ | student_id | int | | student_name | varchar | ------------------------ 在 SQL 中&#xff0c;主键为 student_id&#xff08;学生ID&#xff09;。 该表内的每…

What is `@PathVariable` does?

PathVariable 是SpringMVC中的注解&#xff0c;用于将HTTP请求的URI路径变量映射到Controller方法参数上。 当URL路径中包含占位符&#xff08;由大括号 {} 包围的部分&#xff09;时&#xff0c;可以使用此注解来绑定这些动态部分到方法参数。 使用样例 获取单个路径变量 …

在控制理论里,单个输入变量被施加了饱和特性处理,那么后续怎么利用李雅普诺夫判据判断系统稳定性呢?

在控制理论中&#xff0c;当一个系统的输入变量被施加了饱和特性&#xff08;即输入被限制在某个范围内&#xff09;&#xff0c;系统的稳定性分析可能变得更复杂。使用李雅普诺夫方法判断这样的系统稳定性通常需要考虑非线性特性。下面是如何使用李雅普诺夫方法进行稳定性分析…

多机TCP通讯之hello world(C++)

文章目录 TCP是什么准备工作CMakeLists.txt服务端代码客户端代码参考 TCP是什么 TCP&#xff08;传输控制协议&#xff09;是一种在计算机网络中广泛使用的协议&#xff0c;它提供了可靠的、面向连接的数据传输服务。TCP 是 OSI 模型中的传输层协议&#xff0c;它确保了数据的…

[NAND Flash 6.4] NAND FLASH基本读操作及原理_NAND FLASH Read Operation源码实现

依公知及经验整理,原创保护,禁止转载。 专栏 《深入理解NAND Flash》 <<<< 返回总目录 <<<< ​全文 6000 字 内容摘要 NAND Flash 引脚功能 读操作步骤 NAND Flash中的特殊硬件结构 NAND Flash 读写时的数据流向 Read 操作时序 读时序操作过…