java 静态链表实现示例详解

 更新时间:2023年06月02日 14:18:33   作者:雨翔河  
这篇文章主要为大家介绍了java 静态链表实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

正文

试着用 java 来实现下链表,因为 java 没有指针概念的缘故,用数组的下标来代替指针,这样一个静态链表就出来了。

静态双向不循环链表

public class Test {
    public static void main(String[] args) {
        L l = new L();
        l.init();
        l.insert(123);
        l.insert(456);
        l.insert(789);
        l.insert(222);
        int removeIndex = l.insert(333);
        l.show();
        l.removeNode(removeIndex);
        l.show();
        System.exit(0);
    }
}
/**
 * 静态链表
 */
class L {
    private static final int MAX = 100;  //链表的最大容量
    private Node node[] = new Node[MAX];
    private int head;  //头指针,头指针区域可存储数据也可以不存储数据,只用来做向导,我这里是存储了数据.
    class Node {
        public int next = -1;  //指针指向的后一个节点
        public int pre = -1;  //指针指向的前一个节点
        public long value = -1;  //节点的值
    }
    /**
     * 初始化链表空间,其实这个可以在实例化类的时候完成的.
     */
    public void init() {
        head = 0;
        for (int i = 0; i < MAX; i++) {
            node[i] = new Node();
            node[i].next = -1;  //为了简单的实现下,假设空值为-1
            node[i].pre = -1;
            node[i].value = -1;
        }
    }
    /**
     * 分配节点空间,类似于c里的malloc
     *
     * @return int
     */
    public int malloc() {
        for (int i = 0; i < MAX; i++) {
            if (node[i].pre < 0 && node[i].next < 0 && node[i].value < 0) {
                return i;
            }
        }
        System.out.println("malloc fail ,full");
        return -1;
    }
    /**
     * 移除节点
     *
     * @param indexNode indexNode
     */
    public void removeNode(int indexNode) {
        if (indexNode < 0) {
            System.out.println("removeNode indexNode is error");
            return;
        }
        int preNode = node[indexNode].pre;
        int nextNode = node[indexNode].next;
        node[indexNode].pre = -1;
        node[indexNode].next = -1;
        node[indexNode].value = -1;
        if (nextNode >= 0) {
            node[nextNode].pre = preNode;
        }
        //头节点被移除
        if (preNode < 0) {
            head = nextNode;
        } else {
            node[preNode].next = nextNode;
        }
    }
    /**
     * 插入节点
     *
     * @param v v
     */
    public int insert(long v) {
        int index = head;
        while (node[index].next >= 0) {
            index = node[index].next;
        }
        int insertNodeIndex = malloc();
        if (insertNodeIndex < 0) {
            System.out.println("malloc error,please check malloc function.");
            return -1;
        }
        node[insertNodeIndex].value = v;
        if (insertNodeIndex == head) {
            node[insertNodeIndex].pre = -1;
        } else {
            node[index].next = insertNodeIndex;
            node[insertNodeIndex].pre = index;
        }
        return insertNodeIndex;
    }
    /**
     * 测试下显示这个链表
     */
    public void show() {
        int index = head;
        System.out.println("show l:-------------------------");
        while (node[index].next >= 0) {
            System.out.println(node[index].value);
            index = node[index].next;
        }
        System.out.println(node[index].value);
        System.out.println("show l end:-----------------------");
        System.out.println("test show l start:_______________");
        while (node[index].pre >= 0) {
            System.out.println(node[index].value);
            index = node[index].pre;
        }
        System.out.println(node[index].value);
        System.out.println("test show l end:_______________");
    }
}

以上就是java 静态链表实现示例详解的详细内容,更多关于java 静态链表的资料请关注脚本之家其它相关文章!

相关文章

  • Java使用Poi导出Excel表格方法实例

    Java使用Poi导出Excel表格方法实例

    这篇文章主要给大家介绍了关于Java使用Poi导出Excel表格的相关资料,Java POI是一个用于操作Microsoft Office格式的Java API库,可以使用它来导出Excel文件,需要的朋友可以参考下
    2023-10-10
  • Java反射机制的讲解

    Java反射机制的讲解

    今天小编就为大家分享一篇关于Java反射机制的讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-04-04
  • Java如何获得泛型类中的泛型类型T.class

    Java如何获得泛型类中的泛型类型T.class

    获取泛型符号E的Class对象的方法,1.反射方案利用匿名子类实例化,但该方法有特殊限制,2.反射方案2直接指定泛型类型,但不灵活,3.构造方法方案在初始化时传入泛型类,但有写错风险
    2024-12-12
  • 新手初学Java数组

    新手初学Java数组

    数组是相同类型数据的有序集合数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成。其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们数组的声明创建
    2021-07-07
  • Java中的堆和栈示例详解

    Java中的堆和栈示例详解

    在Java中,堆(Heap)和栈(Stack)是两种不同的内存区域,本文给大家介绍Java中的堆和栈,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2025-09-09
  • springboot扫描引入jar包的service等组件方式

    springboot扫描引入jar包的service等组件方式

    这篇文章主要介绍了springboot扫描引入jar包的service等组件方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • j2Cache线上异常排查问题解决记录分析

    j2Cache线上异常排查问题解决记录分析

    这篇文章主要为大家介绍了关于j2Cache线上异常排查的问题解决记录分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-02-02
  • SpringCloud+Nacos多服务多实例本地测试过程

    SpringCloud+Nacos多服务多实例本地测试过程

    文章介绍了如何使用Nacos进行服务注册与发现,通过配置和启动不同实例来实现服务的高可用性,并展示了如何在前端调用服务接口,确保系统的稳定运行
    2026-02-02
  • 解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

    解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

    本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常问题,通过排查和总结,作者发现使用MyBatis-Plus Boot Starter可以解决这个问题,文章详细对比了MyBatis-Plus Boot Starter和MyBatis Spring Boot Starter的功能和使用场景
    2025-01-01
  • Java常用工具类汇总 附示例代码

    Java常用工具类汇总 附示例代码

    这篇文章主要介绍了Java常用工具类汇总 附示例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04

最新评论