力扣-234.回文链表

题目描述

给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。

cpp 复制代码
class Solution {
public:
    bool isPalindrome(ListNode* head) {
        //快慢指针找到中间结点p1(偶数个结点停在中左)
        ListNode* p1 = head;
        ListNode* p2 = head->next;
        if(p2==nullptr)
            return true;
        while (p2!=nullptr&&p2->next!= nullptr){
            p1=p1->next;
            p2=p2->next->next;
        }
        //后半段头插法逆置
        p2=p1->next;
        p1->next=nullptr;
        while (p2!= nullptr){
            ListNode* temp = p2;
            p2=p2->next;
            temp->next=p1->next;
            p1->next=temp;
        }
        //比较前半段与后半段是否重合
        p2=head;
        p1=p1->next;
        while (p1!= nullptr){
            if(p1->val!=p2->val)
                return false;
            p1=p1->next;
            p2=p2->next;
        }
        return true;
    }
};

小结: 这种做法思路比较清晰,而且可以满足O(n) 时间复杂度和 O(1) 空间复杂度

相关推荐
gfdhy12 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
百***060112 小时前
SpringMVC 请求参数接收
前端·javascript·算法
一个不知名程序员www13 小时前
算法学习入门---vector(C++)
c++·算法
云飞云共享云桌面14 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
福尔摩斯张14 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
橘颂TA14 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展
Dream it possible!15 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树的最小绝对差(85_530_C++_简单)
c++·leetcode·面试
xxxxxxllllllshi15 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L15 小时前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先
铁手飞鹰15 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先