147-data_structure-7-linkedlist~206反转链表

147-data_structure-7-linkedlist~206反转链表

概述

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

测试

1->2->3->4->5
5->4->3->2->1
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

1->2
2->1
输入:head = [1,2]
输出:[2,1]

输入:head = []
输出:[]

解题思路

反转两个节点:将n+1的next指向n

反转多个节点:双指针遍历链表,重复上述操作

解题步骤

双指针一前一后遍历链表

反转双指针

代码

/**
 * 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 p1 = head
  let p2 = null
  while( p1 ) {
    // 保存p1.next的值
    const tmp = p1.next
    // 反转操作
    p1.next = p2
    // p1 p2 双指针遍历
    p2 = p1
    // p1 = p1.next
    p1 = tmp
  }
  return p2
};

复杂度

  • 时间复杂度:O(n)
  • 空间复杂度:O(1)