模拟LinkedList实现的链表(无哨兵)

devtools/2024/11/22 17:32:23/

1.前言

我们将LinkdList视作链表, 底层设计了内部类Node类, 我这里依然没有用到泛型, 其实加上泛型依然很简单, 即将Node节点的数据域的类型由Int转换为E(<E>), 我在此不做赘述.同时实现了增删查改, 遍历等操作.

2.链表(无哨兵)的代码实现

java">public class LinkListTest implements Iterable<Integer>{//头指针static Node head;//内部类private static class Node{//数据域int value;//指针域Node next;public Node(int value, Node nest) {this.value = value;this.next = nest;}}//头插法public void addHead(int value) {Node p = new Node(value, null);p.next = head;head = p;}//遍历链表 : 方式1public void Traversal1() {Node p = head;while (p != null) {System.out.println("该节点的值是" + p.value);p = p.next;}}//获取指定索引位置上的节点的值public int get(int index) {Node p = findIndex(index);return p.value;}//返回指定索引的节点private Node findIndex(int index) {int count = 0;Node p = head;while (count < index) {if (p == null) {throw new IllegalArgumentException();}p = p.next;count++;}return p;}//找到尾节点private Node findLast() {//如果是空链表, 压根找不到最后的节点if (head == null) {return null;}Node p;//当p.next == null时, 则p指向了尾节点for (p = head; p.next != null; p = p.next) {;}return p;}//尾插法public void addLast(int value) {Node last = findLast();//如果是一个空链表if (last == null) {addHead(value);return;}last.next = new Node(value, null);}public void Insert(int index, int value) {//如果插入的是第一个节点if (index == 0) {addHead(value);return;}//先找到index位置处的前一个节点Node p = findIndex(index - 1);p.next = new Node(value, p.next);}//删除最后一个节点public void removeFrist() {//如果是空链表if (head == null) {throw new RuntimeException();}//找到头节点Node p = findIndex(0);head = p.next;}public void remove(int index) {//如果是空链表if (head == null) {throw new RuntimeException();}//如果要删除的是最后一个节点, 那么调用removeFrist()方法if (index == 0) {removeFrist();return;}Node p = findIndex(index - 1);p.next = p.next.next;}//使用迭代器进行遍历@Overridepublic Iterator<Integer> iterator() {return new Iterator<Integer>() {Node q = head;@Overridepublic boolean hasNext() {if (q != null) {return true;}return false;}@Overridepublic Integer next() {int value = q.value;q = q.next;return value;}};}//使用函数式接口进行链表的遍历public void Traverse2(Consumer<Integer> consumer) {for (Node p = head; p != null; p = p.next) {consumer.accept(p.value);}}}

3. 注

  • foreach循环的底层使用了迭代器.所以如果一个类的对象想要使用foreach循环遍历,则其类必须实现Iterable接口,并重写其中的抽象方法(iterable()).在其return语句中实现了匿名内部类,重写了Iterator接口的两个重要的抽象方法,hasNext()和next().不断迭代将next函数返回的值赋值给临时变量element.
  • 在Traverse2方法中,我们使用了函数式接口来进行链表的遍历.
    public void Traverse2(Consumer<Integer> consumer) {for (Node p = head; p != null; p = p.next) {consumer.accept(p.value);}}@Testpublic void test3() {LinkListTest l = new LinkListTest();l.addLast(12);l.addLast(23);l.addLast(34);l.addLast(45);l.addLast(56);l.addLast(67);l.Traverse2(value -> {System.out.println("该节点的值为" + value);});l.Traverse2(System.out :: println);}

    形参是一个消费型的函数式接口,实参我们可以传入接口的实现类的对象(lambda表达式或者方法引用实现).


http://www.ppmy.cn/devtools/15621.html

相关文章

Springboot+Vue项目-基于Java+MySQL的网上购物商城系统(附源码+演示视频+LW)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;Java毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计 &…

巧用断点设置查找bug【debug】

默认设置的断点&#xff0c;当代码运行到断点处MCU就会被挂起&#xff0c;从而停在断点处。 但在某些情况下&#xff0c;如调试FCCU时&#xff0c;如果设置断点&#xff0c;MCU停下后将会导致 FCCU 配置WDG超时。或在调试类似电机控制类的应用时&#xff0c;不适当的断点会导 致…

体验一下使用 ArkUI 进行 HarmonyOS 开发并与 Compose 简单对比

作者&#xff1a;equationl 前言 最近几年各个技术公众号和技术群都在唱衰原生安卓开发&#xff0c;疯狂贩卖焦虑。 搞得我也焦虑的不行&#xff0c;在谷歌的 Compose 推出后就赶紧去学&#xff0c;但是又觉得好像 Compose 的热度也不算太高&#xff0c;又去学 Flutter 。 转…

SQL获取最后一次的数据

问题 有个表格(id,machineName,value,updatetime)&#xff0c;里面比如有10个机台&#xff0c;里面记录了这10个机台的几十万条数据 如何获取每个机台的最后一笔数据&#xff1f; machines表 解决办法 1.首先获得每个机台最后的更新时间 select machineName,max(updatetim…

花粉过敏人群或超2亿?约克VRF中央空调助你健康鲜呼吸

“一朝春雨落,十里桃花开”,暖春、微风、阳光、花香……充满着生机的春天让人心情愉悦,然而对于易过敏人群来说却是“苦不堪言”,经常出现眼圈发红、发痒、睁不开,每天都在“流泪”中度过,同时伴随着咳嗽、打喷嚏、流鼻涕、鼻塞等症状,皮肤也可能会出现红疹、瘙痒等症状。 如何…

MyBatis基础操作

黑马程序员JavaWeb开发教程 文章目录 根据资料中提供的《tlias智能学习辅助系统》页面原型及需求&#xff0c;完成员工管理的需求开发一、环境准备1、准备数据库表emp2、创建一个新的springboot工程&#xff0c;选择引入对应的起步依赖&#xff08;mybatis、mysql驱动、lombok&…

基于SpringBoot的合家云社区物业管理平台 - 数据库设计文档

合家云数据库设计文档V1.0 社区资产模块 社区表:hjy_community字段名称字段类型是否为空值字段释义community_idbigint(20)NO小区idcommunity_namevarchar(128)YES小区名称community_codevarchar(128)YES小区编码community_provence_codevarchar(32)YES省区划码community_cit…

GitLab存储空间满了

1. 背景 前两天同事反馈&#xff0c;代码推送不到服务器了&#xff0c;GitLab报500错误&#xff0c;我等了一天都变好。登录服务器查看GitLab虚拟机&#xff0c;发现磁盘满了。于是用如下命令释放出了一部分空间&#xff1a; journalctl --vacuum-time1s 释放了1秒前的日志&am…