LeetCode练题三:链表

目录

206、反转链表

2、两数相加

141、环形链表


在javascript中链表就是一个对象,只是这个对象的形状如下

javascript 复制代码
const root = {
    val: 1,
    next: {
        val: 2,
        next: {
            val: 3,
            next: {
                val: 4,
                next: null
            }
        }
    }
}

删除某个节点就是

javascript 复制代码
function deleteNode = (node) => {
    node.val = node.next.val
    node.next = node.next.next
}

206、反转链表

javascript 复制代码
var reverseList = function(head) {
    let p1 = head
    let p2 = null
    while(p1){
        const tmp = p1.next
        p1.next = p2
        p2 = p1
        p1 = tmp
    }
    return p2
};

// 就是题目中head = [1,2,3,4,5] 其实是head -> 1 -> 2 -> 3 -> 4 -> 5这样

//就是p1一直等于自己的下一堆,然后P2是等于p1的头指针然后指向自己的一堆

//p1的下一堆越来越少,p2中前面越来越多由p1提供来的节点

就是链表是链表,链表是个数据结构,要用指针来遍历里面的内容

2、两数相加

javascript 复制代码
var addTwoNumbers = function(l1, l2) {
    const l3 = new ListNode(0);
    let p1 = l1
    let p2 = l2
    let p3 = l3
    let carry = 0
    while (p1 || p2) {
        const v1 = p1 ? p1.val : 0
        const v2 = p2 ? p2.val : 0
        const v3 = carry + v1 + v2
        carry = Math.floor(v3 / 10)
        p3.next = new ListNode(v3 % 10)
        if(p1) p1 = p1.next
        if(p1) p2 = p2.next
        p3 = p3.next
    }
    if (carry) {
        p3.next = new ListNode(carry)
    }
    return l3.next
};

141、环形链表

判断一个链表是否是环形,就用两个指针去跑这个链表,一个快,一个慢,要是遇得到相等的,就是环,不是相等的,他自己就会退出循环

javascript 复制代码
var hasCycle = function(head) {
    let p1 = head
    let p2 = head
    while(p1 && p2 && p2.next) {
        p1 = p1.next
        p2 = p2.next.next
        if (p1 === p2) {
            return true
        }
    }
    return false
};
相关推荐
深邃-31 分钟前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
We་ct3 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程7 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮8 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说8 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove9 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung9 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了9 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL10 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰10 小时前
C++ 排列组合完整指南
开发语言·c++·算法