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

相关推荐
Moment12 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
爱敲代码的小鱼12 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
月挽清风12 小时前
代码随想录第十五天
数据结构·算法·leetcode
铅笔侠_小龙虾14 小时前
Flutter 实战: 计算器
开发语言·javascript·flutter
TracyCoder12314 小时前
LeetCode Hot100(34/100)——98. 验证二叉搜索树
算法·leetcode
大模型玩家七七14 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
2501_9447114315 小时前
JS 对象遍历全解析
开发语言·前端·javascript
发现一只大呆瓜15 小时前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
阔皮大师15 小时前
INote轻量文本编辑器
java·javascript·python·c#
lbb 小魔仙15 小时前
【HarmonyOS实战】React Native 表单实战:自定义 useReactHookForm 高性能验证
javascript·react native·react.js