243.回文链表

给你一个单链表的头节点 head ,请你判断该链表是否为

回文链表
。如果是,返回 true ;否则,返回 false

示例 1:

复制代码
输入:head = [1,2,2,1]
输出:true

示例 2:

复制代码
输入:head = [1,2]
输出:false

思路:

  1. 找到前半部分链表的尾节点。
  2. 反转后半部分链表。
  3. 判断是否回文。
  4. 恢复链表。
  5. 返回结果。
cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
 //链表逆序(头插法)
 struct ListNode* reverseList(struct ListNode* head)
 {
    struct ListNode* list,*p;
    list=(struct ListNode*)malloc(sizeof(struct ListNode));
    list->next=NULL;//先建立一个带头结点的单链表
    p=head;
    struct ListNode* s;
    while(p!=NULL)
    {
        //头插法
        s=(struct ListNode*)malloc(sizeof(struct ListNode));
        s->val=p->val;
        s->next=list->next;
        list->next=s;
        p=p->next;
    }
    return list->next;
 }
 //找到前半部分链表的尾节点
 struct ListNode* endOfFirstHalf(struct ListNode* head) {
    struct ListNode* fast = head;
    struct ListNode* slow = head;
    while (fast->next != NULL && fast->next->next != NULL) {
        fast = fast->next->next;
        slow = slow->next;
    }
    return slow;
}
bool isPalindrome(struct ListNode* head) {
    if(head==NULL)
    {
         return true;
    }
    //找到前半部分链表的尾节点并反转后半部分链表
    struct ListNode* firstHalfEnd=endOfFirstHalf(head);
    struct ListNode* secondHalfStart=reverseList(firstHalfEnd->next);
    //判断是否是回文
    struct ListNode* p1=head;
    struct ListNode* p2=secondHalfStart;
    bool result=true;
    while(result &&p2!=NULL)
    {
        if(p1->val!=p2->val)
        {
            result=false;
        }
        p1=p1->next;
        p2=p2->next;
    }
    //还原链表并返回结果
     firstHalfEnd->next = reverseList(secondHalfStart);
     return result;
}
相关推荐
pusue_the_sun1 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
liang_jy7 小时前
数组(Array)
数据结构·面试·trae
要做朋鱼燕7 小时前
【数据结构】用堆解决TOPK问题
数据结构·算法
秋难降8 小时前
LRU缓存算法(最近最少使用算法)——工业界缓存淘汰策略的 “默认选择”
数据结构·python·算法
Jayyih10 小时前
嵌入式系统学习Day19(数据结构)
数据结构·学习
DdduZe11 小时前
8.19作业
数据结构·算法
PyHaVolask11 小时前
链表基本运算详解:查找、插入、删除及特殊链表
数据结构·算法·链表
1白天的黑夜112 小时前
链表-2.两数相加-力扣(LeetCode)
数据结构·leetcode·链表
花开富贵ii13 小时前
代码随想录算法训练营四十六天|图论part04
java·数据结构·算法·图论
熬了夜的程序员13 小时前
【LeetCode】16. 最接近的三数之和
数据结构·算法·leetcode·职场和发展·深度优先