legongju.com
我们一直在努力
2025-01-11 08:46 | 星期六

listnode java如何实现节点删除

在Java中,我们可以使用链表数据结构来实现 ListNode。要实现节点删除,我们需要遵循以下步骤:

  1. 定义一个 ListNode 类,包含一个整数值和一个指向下一个节点的引用。
  2. 创建一个链表类,包含一个头节点引用,并提供添加、删除和查找节点的方法。
  3. 实现删除节点的方法,根据给定的值找到要删除的节点,并将其从链表中移除。

以下是一个简单的实现:

// 定义 ListNode 类
class ListNode {
    int val;
    ListNode next;

    ListNode(int val) {
        this.val = val;
        this.next = null;
    }
}

// 定义链表类
class LinkedList {
    ListNode head;

    // 添加节点到链表头部
    public void add(int val) {
        ListNode newNode = new ListNode(val);
        newNode.next = head;
        head = newNode;
    }

    // 删除指定值的节点
    public void delete(int val) {
        if (head == null) {
            return;
        }

        // 如果头节点就是要删除的节点
        if (head.val == val) {
            head = head.next;
            return;
        }

        ListNode current = head;
        while (current.next != null) {
            if (current.next.val == val) {
                current.next = current.next.next;
                return;
            }
            current = current.next;
        }
    }

    // 查找指定值的节点
    public ListNode find(int val) {
        ListNode current = head;
        while (current != null) {
            if (current.val == val) {
                return current;
            }
            current = current.next;
        }
        return null;
    }
}

使用示例:

public class Main {
    public static void main(String[] args) {
        LinkedList list = new LinkedList();
        list.add(1);
        list.add(2);
        list.add(3);
        list.add(4);

        System.out.println("Original list:");
        printList(list);

        list.delete(2);
        System.out.println("List after deleting 2:");
        printList(list);
    }

    // 打印链表
    public static void printList(LinkedList list) {
        ListNode current = list.head;
        while (current != null) {
            System.out.print(current.val + " -> ");
            current = current.next;
        }
        System.out.println("null");
    }
}

输出:

Original list:
1 -> 2 -> 3 -> 4 -> null
List after deleting 2:
1 -> 3 -> 4 -> null

未经允许不得转载 » 本文链接:https://www.legongju.com/article/3076.html

相关推荐

  • java如何打印菱形

    java如何打印菱形

    在Java中,要打印一个菱形,你可以使用嵌套循环
    public class Diamond { public static void main(String[] args) { int n = 5; // 菱形的大小,可以根据需...

  • java如何输出数组的所有子集

    java如何输出数组的所有子集

    在Java中,可以使用递归的方法来输出数组的所有子集。以下是一个示例代码:
    import java.util.ArrayList;
    import java.util.Arrays;
    import java...

  • java如何打印请求报文

    java如何打印请求报文

    在Java中,要打印HTTP请求报文,你可以使用Java的网络编程库,例如java.net.HttpURLConnection。以下是一个简单的示例,展示了如何使用HttpURLConnection发送GET...

  • 打印直角三角形java怎么实现

    打印直角三角形java怎么实现

    在Java中,可以使用嵌套循环来实现打印直角三角形。以下是一个示例代码:
    public class RightTriangle { public static void main(String[] args) { int n ...

  • php workman怎样安装配置

    php workman怎样安装配置

    Workerman是一个纯PHP编写的高性能的Socket服务器框架,可以用于开发长连接应用,如Websocket、实时聊天室等。以下是安装和配置Workerman的步骤:
    安装Work...

  • java csdn怎样提升影响力

    java csdn怎样提升影响力

    在CSDN上提升影响力需要时间和努力,以下是一些建议: 持续更新内容: 定期发布高质量的原创文章,分享你的技术见解和经验。
    确保内容具有深度和广度,能够...

  • java csdn社区如何管理

    java csdn社区如何管理

    CSDN社区是一个面向开发者的技术社区,它本身并不是基于Java开发的,而是由CSDN网站运营和管理。不过,我可以为您提供一些关于社区管理的建议,这些建议适用于大...

  • java csdn问答怎样提问

    java csdn问答怎样提问

    在CSDN问答平台上提问时,为了得到更好的回答,请遵循以下建议: 问题描述清晰明了:详细描述您遇到的问题,包括已经尝试过的解决方法、代码示例、错误信息等。 ...