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;
}
相关推荐
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧33 分钟前
C语言_数据结构总结6:链式栈
c语言·开发语言·数据结构·算法·链表·visualstudio·visual studio
于慨34 分钟前
数据结构(王卓版)
数据结构
田梓燊43 分钟前
leetcode 95.不同的二叉搜索树 Ⅱ
数据结构·算法·leetcode
情深不寿3172 小时前
数据结构--AVL树
数据结构·c++
孑么3 小时前
力扣 编辑距离
java·数据结构·算法·leetcode·职场和发展·贪心算法·动态规划
手握风云-4 小时前
Java数据结构第二十期:解构排序算法的艺术与科学(二)
数据结构·算法·排序算法
Archer19412 小时前
C语言——链表
c语言·开发语言·链表
开心比对错重要12 小时前
leetcode69.x 的平方根
数据结构·算法·leetcode
Doopny@13 小时前
数字组合(信息学奥赛一本通-1291)
数据结构·算法·动态规划
君莫愁。13 小时前
【Unity】搭建基于字典(Dictionary)和泛型列表(List)的音频系统
数据结构·unity·c#·游戏引擎·音频