一、题目
函数原型:
bool chkPalindrome(ListNode* A)
二、思路判断一个单链表是否为回文结构,由于单链表不能倒序遍历,所以需要找到单链表的后半段,并将其逆置,再与前半段链表进行比较。
如何找到单链表的后半段呢?
如果链表结点数为偶数个,只要找到单链表的第二个中间结点即可。
如果链表节点数为奇数个,只要找到单链表中间结点的下一个结点即可。
本题相关题目:
相关题解:
leetcode:876. 链表的中间结点-CSDN博客
三、代码
cpp/* struct ListNode { int val; struct ListNode *next; ListNode(int x) : val(x), next(NULL) {} };*/ #include <cstddef> ListNode* reserve(ListNode *pphead)//逆置链表函数 { if(pphead==NULL||pphead->next==NULL) return pphead; else { ListNode *prev =NULL; ListNode *cur=pphead; ListNode *next=pphead->next; while(cur) { cur->next=prev; prev=cur; cur=next; if(next) next=next->next; else next=NULL; } return prev; } } class PalindromeList { public: bool chkPalindrome(ListNode* A) { // write code here ListNode *fast=A; ListNode *slow=A; while(fast)//找链表的第二个中间结点或链表中间结点的下一个结点 { slow=slow->next; if(fast->next) fast=fast->next->next; else fast=NULL; } //逆置链表 // ListNode *B=NULL; // ListNode *tailB=NULL; // while(slow) // { // if(tailB==NULL) // { // B=tailB=slow; // } // else // { // tailB->next=slow; // tailB=slow; // } // slow=slow->next; // } // tailB->next=NULL; ListNode *B=reserve(slow);//逆置链表 ListNode *curA=A; ListNode *curB=B; while(curA&&curB)//比较前半段和后半段链表 { if(curA->val==curB->val) { curA=curA->next; curB=curB->next; } else return false; } return true; } };
牛客网:OR36 链表的回文结构
南林yan2023-11-15 21:19
相关推荐
大江东去浪淘尽千古风流人物28 分钟前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)独好紫罗兰1 小时前
对python的再认识-基于数据结构进行-a003-列表-排序wuhen_n1 小时前
JavaScript内置数据结构努力学算法的蒟蒻1 小时前
day79(2.7)——leetcode面试经典1502401_841495641 小时前
【LeetCode刷题】二叉树的层序遍历AC赳赳老秦1 小时前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升独好紫罗兰2 小时前
对python的再认识-基于数据结构进行-a002-列表-列表推导式2401_841495642 小时前
【LeetCode刷题】二叉树的直径budingxiaomoli2 小时前
优选算法-字符串qq7422349842 小时前
APS系统与OR-Tools完全指南:智能排产与优化算法实战解析