206-反转链表
标签:递归 链表
题目信息
题目地址: 206. 反转链表
题目内容:
javascript
给你单链表的头节点head,请你反转链表,并返回反转后的链表。
示例 1:
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
示例 2:
输入:head = [1,2]
输出:[2,1]
示例 3:
输入:head = []
输出:[]
javascript
提示:
链表中节点的数目范围是 [0, 5000]
-5000 <= Node.val <= 5000
进阶:链表可以选用迭代或递归方式完成反转。你能否用两种方法解决这道题?
题解
解法一
思路:
使用
双指针
思路,定义prev
指针默认为null
,cur
指针默认指向head
,遍历链表,然后确定cur
和prev
直接的指向关系,然后向右移动两个指针
,直到cur === null
的时候结束
temp
的存在是因为我们将cur.next
指向prev
后,向右移动cur
时,会找不到需要移动的位置,所以需要现将cur在原始链表中的next
暂时记录下来,每次循环temp
的值都会改变赋值的顺序为:
1、先声明
temp = cur.next
,保存临时变量,也就是cur.next
初始指向的节点2、将
cur.next
指向prev
,反转cur.next
的指向3、
prev
赋值为cur
(prev = cur)
,将prev
右移一位4、将
cur
赋值为temp
,将cur
右移一位5、当
cur
为null
时,遍历结束最终的反转结果就是
绿色箭头
所展现的,图示如下:
代码实现:
javascript
/**
* Definition for singly-linked list.
* function ListNode(val, next) {
* this.val = (val===undefined ? 0 : val)
* this.next = (next===undefined ? null : next)
* }
*/
/**
* @param {ListNode} head
* @return {ListNode}
*/
var reverseList = function(head) {
let curNode = head
let prevNode = null
while(curNode !== null) {
const tempNode = curNode.next
curNode.next = prevNode
prevNode = curNode
curNode = tempNode
}
return prevNode
};
解法二
思路:
使用
递归
写法,可以参照上面的双指针
写法来,就很容易理解
代码实现:
javascript
/**
* Definition for singly-linked list.
* function ListNode(val, next) {
* this.val = (val===undefined ? 0 : val)
* this.next = (next===undefined ? null : next)
* }
*/
/**
* @param {ListNode} head
* @return {ListNode}
*/
var reverseList = function(head) {
const reverseLinklist = (prev, cur) => {
if(cur === null) return prev
const temp = cur.next
cur.next = prev
/**
下面reverseLinklist函数的传参就相当于方法一中的这两行代码
prevNode = curNode
curNode = tempNode
*/
return reverseLinklist(cur, temp)
}
return reverseLinklist(null, head)
};