java中LinkedList 和 ListNode 的区别

1. LinkedList

LinkedList 是 Java 集合框架中的一个类,位于 java.util 包中。它是一个 双向链表 的实现,提供了丰富的操作方法,可以直接用于存储和操作数据。

特点
  • 基于双向链表实现,每个节点包含前驱和后继指针。

  • 实现了 List 和 Deque 接口,因此既可以作为列表使用,也可以作为队列或双端队列使用。

  • 支持动态增删改查操作。

  • 插入和删除操作效率高(时间复杂度为 O(1)),但随机访问效率低(时间复杂度为 O(n))。

用法
import java.util.LinkedList;

public class Main {
    public static void main(String[] args) {
        // 创建一个 LinkedList
        LinkedList<String> list = new LinkedList<>();

        // 添加元素
        list.add("A");
        list.add("B");
        list.add("C");

        // 在头部和尾部添加元素
        list.addFirst("Start");
        list.addLast("End");

        // 访问元素
        System.out.println(list.get(2)); // 输出: B

        // 删除元素
        list.remove("B");

        // 遍历链表
        for (String s : list) {
            System.out.print(s + " "); // 输出: Start A C End
        }
    }
}

2. ListNode

ListNode 是一个 自定义的链表节点类,通常用于实现单链表或双链表。它不是一个标准的 Java 类,而是开发者根据需求定义的类。

特点
  • 通常包含两个属性:

    • val:存储节点的值。

    • next:指向下一个节点的指针。

  • 如果需要实现双链表,可以增加一个 prev 属性,指向前一个节点。

  • 需要手动实现链表的增删改查操作。

定义
class ListNode {
    int val;        // 节点的值
    ListNode next;  // 指向下一个节点的指针

    // 构造函数
    ListNode(int val) {
        this.val = val;
        this.next = null;
    }
}
用法
public class Main {
    public static void main(String[] args) {
        // 创建链表 1 -> 2 -> 3
        ListNode head = new ListNode(1);
        head.next = new ListNode(2);
        head.next.next = new ListNode(3);

        // 遍历链表
        ListNode current = head;
        while (current != null) {
            System.out.print(current.val + " "); // 输出: 1 2 3
            current = current.next;
        }

        // 在链表末尾添加节点 4
        current = head;
        while (current.next != null) {
            current = current.next;
        }
        current.next = new ListNode(4);

        // 删除节点 2
        current = head;
        while (current.next != null) {
            if (current.next.val == 2) {
                current.next = current.next.next;
                break;
            }
            current = current.next;
        }

        // 再次遍历链表
        current = head;
        while (current != null) {
            System.out.print(current.val + " "); // 输出: 1 3 4
            current = current.next;
        }
    }
}

3. LinkedList 和 ListNode 的区别

特性LinkedListListNode
类型Java 标准库中的集合类自定义的链表节点类
实现双向链表单链表或双链表(根据定义)
功能提供了丰富的操作方法(如 addremove 等)需要手动实现链表的操作
使用场景直接用于存储和操作数据用于实现自定义链表或解决算法问题
复杂度封装了底层实现,使用简单需要手动管理指针,灵活性高但复杂度高
示例LinkedList<Integer> list = new LinkedList<>();ListNode head = new ListNode(1);

4. 如何选择使用 LinkedList 和 ListNode

  • 使用 LinkedList

    • 当需要一个现成的链表数据结构时。

    • 当需要频繁进行插入、删除操作时。

    • 当不需要手动管理链表节点时。

  • 使用 ListNode

    • 当需要实现自定义链表时。

    • 当解决算法问题时(如 LeetCode 中的链表题目)。

    • 当需要更灵活地控制链表的结构和行为时。


5. 总结

  • LinkedList 是 Java 标准库中的双向链表实现,适合直接使用。

  • ListNode 是自定义的链表节点类,适合实现自定义链表或解决算法问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值