《剑指offer》面试题16 反转链表 Java版

(输入链表的头节点,反转链表)

书中方法:对于一个链表,我们只能从头往后遍历,如果要反转,我们需要更改当前节点的next域指向前一个节点,此时链表断开,为了能继续修改下一个节点的next域,我们还要维护下一个节点。

	public ListNode reverse(ListNode first){
		if(first == null)return first;
		ListNode last = null;
		ListNode now = first;
		ListNode next = first.next;
		while(now != null){
			now.next = last;
			
			last = now; 
			now = next;
			if(now != null){
				next = now.next;
			}
		}
		return last;
	}

方法二:书后面还提到了递归的方法。自己写的逻辑比较不清楚,在网上找了一个版本。这个方法的思路是:递归返回的是当前节点右侧已经反转好的链表的头节点,对于当前的节点,将它连接到已经reverse好的链表的末尾,返回值是添加了该节点的新链表头。先递归后处理,最后的返回值是反转后的节点,每次递归返回的是添加了当前节点的反转后的链表。注意递归出口的处理。

	public ListNode reverse2(ListNode first){
		if(first == null || first.next == null)return first;
		
		ListNode newHead = reverse2(first.next);
		first.next.next = first;
		first.next = null;
		
		return newHead;
		
	}
posted @ 2019-09-30 11:26  CrazyJack  阅读(180)  评论(0)    收藏  举报