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;
}
相关推荐
智码未来学堂1 天前
探秘 C 语言算法之枚举:解锁解题新思路
c语言·数据结构·算法
青桔柠薯片1 天前
数据结构:顺序表与链表
数据结构·链表
金枪不摆鳍1 天前
算法--二叉搜索树
数据结构·c++·算法
向哆哆1 天前
画栈 · 跨端画师接稿平台:基于 Flutter × OpenHarmony 的整体设计与数据结构解析
数据结构·flutter·开源·鸿蒙·openharmony·开源鸿蒙
季明洵1 天前
C语言实现顺序表
数据结构·算法·c·顺序表
历程里程碑1 天前
Linxu14 进程一
linux·c语言·开发语言·数据结构·c++·笔记·算法
Snow_day.1 天前
有关线段树应用(1)
数据结构·算法·贪心算法·动态规划·图论
wengqidaifeng1 天前
探索数据结构(二):空间复杂度
c语言·开发语言·数据结构
Once_day1 天前
代码训练总结(1)算法和数据结构的框架思维
数据结构·算法
鹿角片ljp1 天前
力扣125.验证回文串-双指针
数据结构·算法