單鏈表反轉(遞歸和非遞歸) (Java)


鏈表定義

class ListNode {
    int val;
    ListNode next;

    ListNode(int x) {
        val = x;
    }
}
View Code

 

非遞歸實現很簡單,只需要遍歷一遍鏈表,在遍歷過程中,把遍歷的節點一次插入到頭部。

public ListNode reverseList(ListNode head) {
        ListNode prev = null;
        while(head!=null){
            ListNode tmp = head.next;
            head.next = prev;
            prev = head;
            head = tmp;
        }
        return prev;
    }
View Code

 

遞歸實現:翻轉head->為首的鏈表, 然后head變為尾部節點

public ListNode reverseList(ListNode head) {
        if(head==null||head.next ==null)
            return head;
        ListNode prev = reverseList(head.next);
        head.next.next = head;
        head.next = null;
        return prev;
    }
View Code

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM