单链表反转(递归和非递归) (Java)

链表定义

《单链表反转(递归和非递归) (Java)》
《单链表反转(递归和非递归) (Java)》

class ListNode {
    int val;
    ListNode next;

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

View Code

 

非递归实现很简单,只需要遍历一遍链表,在遍历过程中,把遍历的节点一次插入到头部。

《单链表反转(递归和非递归) (Java)》
《单链表反转(递归和非递归) (Java)》

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变为尾部节点

《单链表反转(递归和非递归) (Java)》
《单链表反转(递归和非递归) (Java)》

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

 

    原文作者:smile_tina
    原文地址: https://www.cnblogs.com/tina-smile/p/4878983.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞