IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> Java实现单链表的尾插法和根据值进行删除 -> 正文阅读

[数据结构与算法]Java实现单链表的尾插法和根据值进行删除

作者:recommend-item-box type_blog clearfix
  • delete方法里面的while (head != null)判断的相关示意图
    在这里插入图片描述
  • 代码
public class LinkedNode {

    Node head;
    int data;

    // 头插法
    public void add(int value) {
        Node newNode = new Node(value);
        if (this.head == null) {
            this.head = newNode;
            return;
        }
        newNode.next = this.head;
        this.head = newNode;
    }

    // 根据值进行删除
    public void delete(int value) {
        if (this.head == null) {
            throw new RuntimeException("无法对空链表进行删除");
        }
        // pre为 head的前一个值,因为head判断自己等于value时候,就需要用到前一个值(pre)和后一个(head.next);
        Node pre = this.head;
        // 定义一个变量head,后面会改变引用地址
        Node head = this.head;
        while (head != null) {
            if (head.data == value) {
                // 一旦发现,就把pre赋值给自己;
                head = pre;
                // 此时head为 value对应的节点的 前面;
                head.next = head.next.next;
            } else {
                pre = head;
                // 引用地址改变
                head = head.next;
            }
        }
    }

    //display  打印该链表
    public void display() {
        if (this.head == null) {
            System.out.println("The List is empty.");
            return;
        }
        Node cur = this.head;
        StringBuilder stringBuilder = new StringBuilder();
        while (cur != null) {
            //System.out.print(cur.data + " -> ");
            stringBuilder.append(cur.data + " -> ");
            cur = cur.next;
        }
        System.out.println(stringBuilder.append("NULL").toString());
    }

    public static void main(String[] args) {
        LinkedNode linkedNode = new LinkedNode();
        linkedNode.add(1);
        linkedNode.add(2);
        linkedNode.add(3);
        linkedNode.add(3);
        linkedNode.add(4);
        System.out.println("初始模样");
        linkedNode.display();
        linkedNode.delete(3);
        System.out.println("删除3");
        linkedNode.display();
        System.out.println("删除1");
        linkedNode.delete(1);
        linkedNode.display();
    }

    //构造一个节点类
    class Node {
        public int data;
        public Node next;

        public Node(int data) {
            this.data = data;
        }
    }
}
  • 结果
    在这里插入图片描述
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-07 22:56:50  更:2022-04-07 23:01:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 4:51:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码