LinkedList链表如何进行反转操作

发布时间:2025-05-19 11:58:29 作者:小樊
来源:亿速云 阅读:109

LinkedList 链表的反转操作可以通过迭代或递归的方式实现。这里分别给出两种方法的 Java 实现。

  1. 迭代方法:
public ListNode reverseList(ListNode head) {
    ListNode prev = null;
    ListNode current = head;
    ListNode next = null;
    
    while (current != null) {
        next = current.next; // 保存下一个节点
        current.next = prev; // 反转当前节点的指针
        prev = current; // 将 prev 移动到当前节点
        current = next; // 将 current 移动到下一个节点
    }
    
    return prev; // 返回新的头节点
}
  1. 递归方法:
public ListNode reverseList(ListNode head) {
    if (head == null || head.next == null) {
        return head;
    }
    
    ListNode newHead = reverseList(head.next); // 递归反转剩余部分
    head.next.next = head; // 将当前节点添加到反转后的链表末尾
    head.next = null; // 将当前节点的 next 指针置为 null
    
    return newHead; // 返回新的头节点
}

这两种方法都可以实现 LinkedList 链表的反转操作。迭代方法的时间复杂度为 O(n),空间复杂度为 O(1);递归方法的时间复杂度为 O(n),空间复杂度为 O(n)。在实际应用中,可以根据具体需求选择合适的方法。

推荐阅读:
  1. 项目中MySQL数据源转SQL server数据源Dual无效
  2. 记一次Oracle释放表空间,还原数据实操

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:Java中BigDecimal如何进行模运算

下一篇:LinkedList链表如何进行排序操作

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》