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.再次反转复原链表

相关推荐
利刃大大1 天前
【Vue】Vue2 和 Vue3 的区别
前端·javascript·vue.js
Lhuu(重开版1 天前
JS:正则表达式和作用域
开发语言·javascript·正则表达式
yuguo.im1 天前
我开源了一个 GrapesJS 插件
前端·javascript·开源·grapesjs
安且惜1 天前
带弹窗的页面--以表格形式展示
前端·javascript·vue.js
qeen871 天前
【数据结构】单链表及双向链表的解析与实现
数据结构·链表
摘星编程1 天前
用React Native开发OpenHarmony应用:NFC读取标签数据
javascript·react native·react.js
菜鸟233号1 天前
力扣213 打家劫舍II java实现
java·数据结构·算法·leetcode
狐571 天前
2026-01-18-LeetCode刷题笔记-1895-最大的幻方
笔记·算法·leetcode
AGMTI1 天前
webSock动态注册消息回调函数功能实现
开发语言·前端·javascript
Q741_1471 天前
C++ 队列 宽度优先搜索 BFS 力扣 662. 二叉树最大宽度 每日一题
c++·算法·leetcode·bfs·宽度优先