24.判断回文链表

1.题目描述

2.思路

前面两题都是为了这一题做准备的,思路就是双指针先找到中间节点,然后翻转后半段,然后依次对比即可

3.代码

cpp 复制代码
bool isPalindrome(struct ListNode* head) {
   if (head == NULL || head->next == NULL) {
        return true;
    }
    struct ListNode* p1 = head;
    int len = 0;
    while(p1!=NULL){
        len++;
        p1 = p1->next;
    }

    int mid = len/2;//找到后半段的首个节点
    p1 = head;//继续用p1
    while(mid>0){
        p1 = p1->next;
        mid--;
    }//此时p1指向后半段
    //开始反转后半段
    struct ListNode* pre = NULL;
    struct ListNode* cur = p1;
    struct ListNode* nextp=NULL;
    while(cur!=NULL){
        nextp = cur->next;
        cur->next = pre;
        pre = cur;
        cur=nextp;
    }
    //此时cur就是后半段反转的头节点
    //开始判断回文
    while(pre!=NULL){
        if(head->val != pre->val){
            return false;
        }
        pre = pre->next;
        head = head->next;
    }
    return true;
}
相关推荐
LDR0064 分钟前
如何使用OpenClaw提高工作效率?
数据结构·算法
liuyao_xianhui4 分钟前
优选算法_模拟_替换所有的‘?‘_C++
开发语言·javascript·数据结构·c++·算法·链表·动态规划
菜鸟小九13 分钟前
hot100(81-90)
java·数据结构·算法
独自破碎E43 分钟前
【面试真题拆解】5秒内限10次HTTP接口访问,结合数据结构和算法说说你的思路
数据结构·http·面试
扶摇接北海1761 小时前
洛谷:P5732 【深基5.习7】杨辉三角
数据结构·c++·算法
handler011 小时前
算法:Trie树(字典树)
c语言·数据结构·c++·笔记·算法·深度优先
6+h1 小时前
【Redis】数据结构讲解
数据结构·数据库·redis
阿Y加油吧1 小时前
力扣打卡day06——滑动窗口最大值、最小覆盖子串
数据结构·算法·leetcode
沉鱼.441 小时前
日期题目集
数据结构·算法