【924、手写链表翻转】

70 阅读1分钟

以下是Java中手写链表翻转的示例代码。假设已经定义了一个链表节点类 ListNode,其包含一个整数值和一个指向下一个节点的指针。

class ListNode {
    int val;
    ListNode next;

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

public class LinkedListReverse {
    public static ListNode reverseLinkedList(ListNode head) {
        ListNode prev = null;
        ListNode current = head;
        ListNode next;

        while (current != null) {
            next = current.next;
            current.next = prev;
            prev = current;
            current = next;
        }

        return prev; // prev现在成为新链表的头
    }

    public static void printLinkedList(ListNode head) {
        ListNode current = head;
        while (current != null) {
            System.out.print(current.val + " -> ");
            current = current.next;
        }
        System.out.println("null");
    }

    public static void main(String[] args) {
        // 创建一个简单的链表:1 -> 2 -> 3 -> 4 -> 5
        ListNode head = new ListNode(1);
        head.next = new ListNode(2);
        head.next.next = new ListNode(3);
        head.next.next.next = new ListNode(4);
        head.next.next.next.next = new ListNode(5);

        System.out.println("原始链表:");
        printLinkedList(head);

        ListNode reversedHead = reverseLinkedList(head);

        System.out.println("翻转后的链表:");
        printLinkedList(reversedHead);
    }
}

这个代码示例中,reverseLinkedList 方法接受一个链表头节点 head,然后通过遍历链表,反转链表中的节点,最终返回新链表的头节点。printLinkedList 方法用于打印链表,便于检查翻转是否成功。

main 方法中,我们创建了一个简单的链表,然后打印原始链表,之后调用 reverseLinkedList 方法进行翻转,再次打印翻转后的链表,以验证翻转操作的正确性。