【LeetCode】数据结构题解(6)[回文链表]

这篇具有很好参考价值的文章主要介绍了【LeetCode】数据结构题解(6)[回文链表]。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

所属专栏:玩转数据结构题型
博主首页:初阳785
代码托管:chuyang785
感谢大家的支持,您的点赞和关注是对我最大的支持!!!
博主也会更加的努力,创作出更优质的博文!!
关注我,关注我,关注我,重要的事情说三遍!!!!!!!!

1.题目来源

回文链表

2.题目描述

给定一个链表的 头节点 head ,请判断其是否为回文链表。
如果一个链表是回文,那么链表节点序列从前往后看和从后往前看是相同的。
【LeetCode】数据结构题解(6)[回文链表]

3.解题思路

这个题目需要结合之前的几个解题思路。
1.快慢指针
2.查找中间节点
3.反转链表

既然我们要判断是否是回文数,如果他是个数组的话我们就会创建两个变量,一个从头出发,一个从尾出发,一次迭代判断是否相同,这样的话就很好的解决了问题。
但是这里是链表,链表的特点就是它是单向的,你只能找到后一个,但是你找不到前面一个。
那我们就想一下有没有方法可以实现类似于数组的方法呢?

我们先观察一下回文的特点:
【LeetCode】数据结构题解(6)[回文链表]
我们会发现如果是偶数的话左边一半会等于右边一半反转之后的样子。
既然我们不能从尾向头遍历,那我们不妨把后半部分反战过来,让它的尾做头,这样子我们就可以遍历并判断力。

于是我们就得先找到中间节点,并从中间节点开始反转一中间节点尾起点的链表。
【LeetCode】数据结构题解(6)[回文链表]
反转的时候我们得创建一个新的节点newNode,然后头插反转链表:
【LeetCode】数据结构题解(6)[回文链表]
但是我们不要忘记了虽然我们反转链表了,但是上面的3的next还是指向下面3的地址的:
【LeetCode】数据结构题解(6)[回文链表]
将他变成这个样子之后,我们就可以遍历我们的head->val是否等于newNode->val来判断是否是回文链表了。
只要head或者newNode其中一个遍历到了NULL就停止。文章来源地址https://www.toymoban.com/news/detail-434983.html

4.代码展示

bool isPalindrome(struct ListNode* head)
{
    //1.找中间节点
    //快慢指针
    struct ListNode*fast=head,*low=head;
    while(fast && fast->next)//快慢指针退出条件(当链表是偶数后者是奇数的时候)
    {
        low=low->next;
        fast=fast->next->next;
    }
    struct ListNode* midNode=low;
    //2.反转中间节点以后的链表
    struct ListNode* newNode=NULL,*midNext=NULL;
    while(midNode)
    {
        midNext=midNode->next;
        midNode->next=newNode;
        newNode=midNode;
        midNode=midNext;
    }
    //3.迭代判断是否相同
    while(head && newNode)//这里同样的链表可能是偶数也可能是奇数,不知道谁先到达NULL
    {
        if(head->val != newNode->val)
            return false;
        head=head->next;
        newNode=newNode->next;
    }
    return true;
}

到了这里,关于【LeetCode】数据结构题解(6)[回文链表]的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【LeetCode】数据结构题解(12)[用栈实现队列]

    所属专栏:玩转数据结构题型❤️ 🚀 博主首页:初阳785❤️ 🚀 代码托管:chuyang785❤️ 🚀 感谢大家的支持,您的点赞和关注是对我最大的支持!!!❤️ 🚀 博主也会更加的努力,创作出更优质的博文!!❤️ 🚀 关注我,关注我,关注我,重要的事情说三遍!!!!!

    2024年02月13日
    浏览(42)
  • 【LeetCode】数据结构题解(11)[用队列实现栈]

    所属专栏:玩转数据结构题型❤️ 🚀 博主首页:初阳785❤️ 🚀 代码托管:chuyang785❤️ 🚀 感谢大家的支持,您的点赞和关注是对我最大的支持!!!❤️ 🚀 博主也会更加的努力,创作出更优质的博文!!❤️ 🚀 关注我,关注我,关注我,重要的事情说三遍!!!!!

    2024年02月13日
    浏览(39)
  • 【LeetCode】数据结构题解(13)[设计循环链表]

    所属专栏:玩转数据结构题型❤️ 🚀 博主首页:初阳785❤️ 🚀 代码托管:chuyang785❤️ 🚀 感谢大家的支持,您的点赞和关注是对我最大的支持!!!❤️ 🚀 博主也会更加的努力,创作出更优质的博文!!❤️ 🚀 关注我,关注我,关注我,重要的事情说三遍!!!!!

    2024年02月13日
    浏览(56)
  • LeetCode_链表的回文结构

    ✨✨所属专栏:LeetCode刷题专栏✨✨ ✨✨作者主页:嶔某✨✨ 对于一个链表,请设计一个时间复杂度为O(n),额外空间复杂度为O(1)的算法,判断其是否为回文结构。给定一个链表的头指针A,请返回一个bool值,代表其是否为回文结构。保证链表长度小于等于900。 就比如:1-2-3

    2024年04月26日
    浏览(40)
  • 【Leetcode】反转链表 合并链表 相交链表 链表的回文结构

      目录 一.【Leetcode206】反转链表 1.链接 2.题目再现  3.解法A:三指针法 二.【Leetcode21】合并两个有序链表 1.链接 2.题目再现  3.三指针尾插法 三.【Leetcode160】相交链表 1.链接 2.题目再现 3.解法 四.链表的回文结构 1.链接 2.题目再现  3.解法 1.链接 反转链表 2.题目再现  3.解法

    2024年02月02日
    浏览(50)
  • LeetCode 刷题 数据结构 链表 203 移除链表元素

    Given the  head  of a linked list and an integer  val , remove all the nodes of the linked list that has  Node.val == val , and return  the new head . Example 1: Example 2: Example 3: Constraints: The number of nodes in the list is in the range  [0, 104] . 1 = Node.val = 50 0 = val = 50 今天leetcode的中文官网比较卡,所以是登录官网进行

    2024年02月14日
    浏览(36)
  • 【数据结构 | 链表】leetcode 2. 两数相加

    个人主页:兜里游客棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里游客棉花糖 原创 收录于专栏【LeetCode】 原题链接:点击直接跳转到该题目 给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位

    2024年02月05日
    浏览(52)
  • 【数据结构】[LeetCode138. 复制带随机指针的链表]

    给你一个长度为  n  的链表,每个节点包含一个额外增加的随机指针  random  ,该指针可以指向链表中的任何节点或空节点。 构造这个链表的  深拷贝 。 深拷贝应该正好由  n  个  全新  节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的  next  指针和

    2024年02月04日
    浏览(49)
  • 【数据结构】LeetCode升级版的环形链表,复制带随机指针的链表

              1、题目说明           2、题目解析           1、题目说明           2、题目解析      1、题目说明 题目链接: 升级版的环形链表  给定一个链表的头节点 head ,返回链表开始入环的第一个节点。  如果链表无环,则返回NULL。 如果链表中有某个节点,可以通

    2024年01月16日
    浏览(62)
  • 数据结构:带环单链表基础OJ练习笔记(leetcode142. 环形链表 II)(leetcode三题大串烧)

    目录 一.前言  二.leetcode160. 相交链表  1.问题描述 2.问题分析与求解 三.leetcode141. 环形链表 1.问题描述 2.代码思路  3.证明分析  下一题会用到的重要小结论: 四.leetcode142. 环形链表 II 1.问题描述 2.问题分析与求解 Judgecycle接口: 方法一: 方法二:  单链表和带环单链表

    2023年04月08日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包