leetcode-206反转链表

题目:206反转链表

我的解答:

public ListNode reverseList(ListNode head) {
    ListNode tail=null;
    ListNode mid=null;
    while(head!=null){
        mid=head;
        mid.next=tail;
        tail=mid;
        head=head.next;
    }
    return tail;
}

问题分析:ListNode属于类,类之间的赋值属于浅复制,所以将head赋值给mid,即是两个变量共享一个地址,所以任意一个改变指向,该地址的结点都会改变,因此需要做以下改变:

public ListNode reverseList(ListNode head) {
    ListNode tail=null;
    ListNode mid=null;
    while(head!=null){
        mid=head.next;
        head.next=tail;
        tail=head;
        head=mid;
    }
    return tail;
}

你可能感兴趣的:(leetcode-206反转链表)