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;
}
相关推荐
南方的狮子先生22 分钟前
【数据结构】(C++数据结构)查找算法与排序算法详解
数据结构·c++·学习·算法·排序算法·1024程序员节
学编程就要猛1 小时前
数据结构初阶:Java中的ArrayList
java·开发语言·数据结构
试试勇气1 小时前
算法工具箱之双指针
数据结构
在等晚安么1 小时前
力扣面试经典150题打卡
java·数据结构·算法·leetcode·面试·贪心算法
Dobby_052 小时前
【Go】C++转Go:数据结构练习(一)排序算法
数据结构·golang
熬了夜的程序员3 小时前
【LeetCode】90. 子集 II
数据结构·算法·leetcode·链表·职场和发展·排序算法
熬了夜的程序员3 小时前
【LeetCode】91. 解码方法
算法·leetcode·链表·职场和发展·排序算法
大数据张老师3 小时前
数据结构——内部排序算法的选择和应用
数据结构·算法·排序算法
緈福的街口4 小时前
gps的定位图,在车的位置去寻找周围20x20的区域,怎么确定周围有多少辆车,使用什么数据结构
数据结构·算法
风筝在晴天搁浅5 小时前
代码随想录 701.二叉搜索树中的插入操作
数据结构