Skip to content

LeetCode 206. 反转链表

作者:Choi Yang
更新于:17 小时前
字数统计:220 字
阅读时长:1 分钟

题目描述

反转一个单链表。

示例:

javascript
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL

进阶: 你可以迭代或递归地反转链表。你能否用两种方法解决这道题?

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/reverse-linked-list 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路

非递归解法

javascript
/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */
/**
 * @param {ListNode} head
 * @return {ListNode}
 */
function reverseList(head) {
  let pre = null
  let cur = head
  while (cur) {
    const tmp = cur.next
    cur.next = pre
    pre = cur
    cur = tmp
  }
  return pre
}

递归解法

javascript
/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */
/**
 * @param {ListNode} head
 * @return {ListNode}
 */
function reverseList(head) {
  const reverse = (pre, cur) => {
    if (!cur)
      return pre
    const tmp = cur.next
    cur.next = pre
    return reverse(cur, tmp)
  }
  return reverse(null, head)
}
javascript
学如逆水行舟,不进则退

Contributors

Choi Yang
文章作者:Choi Yang
文章链接:
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 ChoDocs