一、反转整个链表
问题:定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL
//单链表的实现结构
public class ListNode {
int val;
ListNode next;
ListNode(int x) {
val = x;}
}
反转链表利用迭代不难实现,如果使用递归则有些许难度。
首先来看源码实现:
ListNode reverse(ListNode head) {
if(head == null || head.next == null)
return head;
ListNode ret = reverse