Leetcode 234.回文链表 JavaScript (Day 9)

js一刷 自解法一

javascript 复制代码
var isPalindrome = function(head) {
    let p1=head 
    let temp=null;
    while(p1.next){
    p1.prev=temp;
    temp=p1;
    p1=p1.next;
    }
    p1.prev=temp;
    let p2=head
    while(p1!=p2){
        if(p1.val!=p2.val) return false;
        p1=p1.prev;
        p2=p2.next;
    } 
    return true;
};

缺点:修改了原链表

js一刷 法二

javascript 复制代码
//找中间结点
 function FindMiddle(head){
    let slow=head,fast=head;
    while(fast!=null&&fast.next!=null){
        slow=slow.next;
        fast=fast.next.next;
    }
    return slow;
 }
//反转链表
function ReserveList(head){
    let rehead=null,cur=head;
    while(cur){
        let temp=cur.next;
        cur.next=rehead;
        rehead=cur;
        cur=temp;
    }
    return rehead; 
}

var isPalindrome = function (head) {
    let flag=true
    let midNode=FindMiddle(head);
    let p1=ReserveList(midNode);
    let p2=head;
    while(p1){
        if(p1.val!=p2.val){
            flag=false;
            break;
        }
        p1=p1.next;
        p2=p2.next;
    }
    //复原链表
    ReserveList(midNode);
    return flag;
};

算法核心:分为四部分
1.找中间节点(快慢指针)
2.反转链表(头插)
3.双指针变量
4.再次反转复原链表

相关推荐
老前端的功夫3 小时前
TypeScript 全局类型声明:declare关键字的深度解析与实战
linux·前端·javascript·ubuntu·typescript·前端框架
EndingCoder3 小时前
TypeScript 入门:理解其本质与价值
前端·javascript·ubuntu·typescript·node.js
2501_946244783 小时前
Flutter & OpenHarmony OA系统弹窗对话框组件开发指南
javascript·flutter·microsoft
烟袅4 小时前
从定时器管理出发,彻底搞懂防抖与节流的实现逻辑
前端·javascript
前端小L4 小时前
贪心算法专题(十三):画地为牢的艺术——「划分字母区间」
javascript·算法·贪心算法
北冥有一鲲4 小时前
A2A协议与LangChain.js实战:构建微型软件工厂
开发语言·javascript·langchain
UIUV4 小时前
JavaScript 遍历方法详解
前端·javascript·代码规范
火车叼位5 小时前
开发者必看:三大 CLI 工具 MCP 配置详解
javascript
拾荒李5 小时前
虚拟列表进阶-手搓不定高虚拟列表实现
javascript·性能优化