LeetCode 数据结构入门 day 8 - 链表

106 阅读2分钟

这是我参与2022首次更文挑战的第8天,活动详情查看:2022首次更文挑战

反转链表

原题地址

题目

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

示例 1:

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

示例 2:

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

示例 3:

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

方法

思路:

  1. this.val 代表当前节点的值,this.next 指向下一个节点,若 this.nextnull,则说明该节点为链表的最后一个节点。
  2. 把下一个节点赋值给当前对象的 next 属性,并且交换 prev 以及 curr

代码:

/**
 * 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 prev = null;
    let curr = head;
    while (curr !== null) {
        let cnext = curr.next;
        curr.next = prev === null ? null : prev
        prev = curr;
        curr = cnext;
    }
    return prev
};

结果:

  • 执行结果: 通过
  • 执行用时:64 ms, 在所有 JavaScript 提交中击败了92.84%的用户
  • 内存消耗:43.3 MB, 在所有 JavaScript 提交中击败了5.00%的用户
  • 通过测试用例:28 / 28

删除排序链表中的重复元素

原题地址

题目

给定一个已排序的链表的头 head, 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。

示例 1:

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

示例 2:

输入:head = [1,1,2,3,3]
输出:[1,2,3]

解题方法

思路:

  1. 新建一个 val 为 -999 的 ListNode

代码:

/**
 * 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 deleteDuplicates = function(head) {
    let res = new ListNode(-999)
    res.next = head
    let s = res
    while(s.next !== null) {
        if(s.next.val === s.val) {
            s.next = s.next.next
        } else {
            s = s.next
        }
    }
    console.log(head, s, res)
    return res.next
};

结果:

  • 执行结果: 通过
  • 执行用时:84 ms, 在所有 JavaScript 提交中击败了49.41%的用户
  • 内存消耗:43.6 MB, 在所有 JavaScript 提交中击败了5.14%的用户
  • 通过测试用例:166 / 166

— END