题目描述:
反转一个单链表。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL
进阶:
你可以迭代或递归地反转链表。你能否用两种方法解决这道题?
迭代法:
思想:新建一个链表,然后将原链表元素依次用尾插法插入到新链表的尾部,依次类推。
代码:
public ListNode reverseList(ListNode head) {
if(head == null) {
return null;
}
//新链表尾部
ListNode newListNode = null;
while(head != null) {
ListNode p = head.next;
head.next = newListNode;
newListNode = head;
head = p;
}
return newListNode;
}
递归法:
这里不多解释,借用一个博客的图:
https://blog.csdn.net/qq_37117521/article/details/80808631
代码:
public ListNode reverseList(ListNode head) {
if(head == null || head.next == null) {
return head;
}
ListNode newHead = reverseList(head.next);
head.next.next = head;
head.next = null;
return newHead;
}