这是我参与2022首次更文挑战的第8天,活动详情查看:2022首次更文挑战。
反转链表
题目
给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
示例 1:
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
示例 2:
输入:head = [1,2]
输出:[2,1]
示例 3:
输入:head = []
输出:[]
方法
思路:
this.val代表当前节点的值,this.next指向下一个节点,若this.next为null,则说明该节点为链表的最后一个节点。- 把下一个节点赋值给当前对象的
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]
解题方法
思路:
- 新建一个 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