链表的回文结构的判定(C语言)怎会如此简单!!!

目录

  • 题目
  • 思路分析
    • 如何找到中间节点
    • 如何实现反转链表
    • 链表的对比
    • 完整代码

题目

链接: 题目
描述:

对于一个链表,请设计一个时间复杂度为O(n),额外空间复杂度为O(1)的算法,判断其是否为回文结构。
给定一个链表的头指针A,请返回一个bool值,代表其是否为回文结构。保证链表长度小于等于900。

举例:

1->2->2->1

返回:true

思路分析

首先,回文结构是链表的一半反转后跟另一半相同,因此,我们可以先找到中间节点,将后半部分给翻转,再跟前半部分对比即可。
这里我们需要三个步骤:
找到中间节点
反转链表
链表对比

如何找到中间节点

看到这里的小伙伴有思路了吗?没错!跟你想的一样,我们可以使用快慢指针,快慢指针指的是使用两个指针,慢指针走一步,快指针走两步,快指针走到最后一个节点(奇数)或者走到空(偶数),则慢指针走到了中间节点。
嘻嘻,有没有一种恍然大悟的感觉,我相信你一定是有的,那到底该如何做呢?请看代码:

 ListNode *slow = A;//A是头节点
        ListNode *fast = A;
        while(fast && fast->next)
        {
            slow = slow->next;//慢指针走一步
            fast = fast->next->next;//快指针走两步
        }

如果fast=NULL,则有偶数个节点
在这里插入图片描述

如果fast->next=NULL,则有奇数个节点
在这里插入图片描述

如何实现反转链表

我们可以使用三个指针变量来实现,创建三个指针变量, 一个指向NULL,一个指向头节点,第三个指向头节点的下一个节点 \colorbox{CadetBlue}{一个指向NULL,一个指向头节点,第三个指向头节点的下一个节点} 一个指向NULL,一个指向头节点,第三个指向头节点的下一个节点
在这里插入图片描述
废话不多说,请看代码的实现:

 		ListNode * p1 = NULL;
        ListNode * p2 = slow;
        ListNode * p3 = p2->next;
        while(p2)
        {
            p2->next = p1;
            p1 = p2;
            p2 = p3;
            if(p3!=NULL)//这里需要防止p3为空
            p3 = p3->next;
        }

嘻嘻!是不是有点小简单…

链表的对比

第一个链表是反转后的链表,第二个原始的链表,第二个节点的指向为data=3的节点
在这里插入图片描述

实际上,图像应该这样画!
在这里插入图片描述
是不是要清晰很多!!!
请看代码:

 ListNode*pp1 = p1;
         ListNode *pp2 = A;
        while(pp1&&pp2)
        {
            if(pp1->val != pp2->val)
            return false;
            pp1 = pp1->next;
            pp2 = pp2->next;
        }

完整代码

 bool chkPalindrome(ListNode* A) {
        // write code here
        ListNode *slow = A;
        ListNode *fast = A;
        while(fast && fast->next)
        {
            slow = slow->next;
            fast = fast->next->next;
        }
        ListNode * p1 = NULL;
        ListNode * p2 = slow;
        ListNode * p3 = p2->next;
        while(p2)
        {
            p2->next = p1;
            p1 = p2;
            p2 = p3;
            if(p3!=NULL)
            p3 = p3->next;
        }
        ListNode*pp1 = p1;
         ListNode *pp2 = A;
        while(pp1&&pp2)
        {
            if(pp1->val != pp2->val)
            return false;
            pp1 = pp1->next;
            pp2 = pp2->next;
        }
        return true;

    }

是不是也挺简单的,感觉就那样儿!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/674600.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

php反序列化中的pop链

目录 一、什么是POP 二、成员属性赋值对象 例题: 方法一 方法二 三、魔术方法的触发规则 例题: 四、POC的编写 例题1: 例题2 [NISACTF 2022]babyserialize 今日总结: 一、什么是POP 在反序列化中,我们…

Git配置免密登录Github

1、登录 GitHub ,点击右上角头像,选中 Settings (设置)。 在 https://github.com 登录你的帐号,登录以后点击右上角你的头像的Settings 如果没有设置,输入下面的指令进行设置: git config --global user.name “用户名…

【启明智显技术分享】sigmastar ssd202d双网口开发板多串口调试说明

提示:作为Espressif(乐鑫科技)大中华区合作伙伴及sigmastar(厦门星宸)VAD合作伙伴,我们不仅用心整理了你在开发过程中可能会遇到的问题以及快速上手的简明教程供开发小伙伴参考。同时也用心整理了乐鑫及星宸…

cesium 的初步认识

Cesium是一个基于JavaScript开发的WebGL三维地球和地图可视化库。它利用了现代Web技术,如HTML5、WebGL和WebAssembly,来提供跨平台和跨浏览器的三维地理空间数据可视化。Cesium的主要特点包括: 跨平台、跨浏览器:无需额外插件&am…

4个免费音频转换器:解放您的音频文件格式转换需求

在日常生活和工作中,我们经常需要处理各种音频文件,但有时候这些文件可能并不是我们需要的特定格式。在这种情况下,一个免费的音频转换器就能派上用场。免费音频转换器是一种非常实用的工具,它可以帮助我们将不同格式的音频文件相…

C++栈、队列

文章目录 目录 文章目录 前言 一、stack、queue介绍 1.stack 2.queue 二、stack、queue的习题 1. 最小栈 2. 栈的压入、弹出序列 3.二叉树的层序遍历 三、stack和queue的模拟实现 1.stack的模拟实现 2.queue的模拟实现 前言 栈和队列是俩种特殊的容器,C在实现栈和队…

contentType 与 dataType

contentType 与 dataType contentType contentType:发送的数据格式(请求方发送给服务器的数据格式),这个内容会放在请求方的 请求头中 application/x-www-form-urlencoded 这个是默认的请求格式。 提交给后台的数据会按照 KV&am…

瑞意教育集团阳光助学 军训展风采 青春正当时2024级新生军训圆满落幕

为推进全民素质教育,弘扬爱国主义精神,增强学生的国防意识,培养顽强的意志品格,5月7日—5月10日,瑞意教育集团举行2024级新生军训活动。 2024年5月7日上午8点,瑞意教育集团2024级新生军训动员大会在学校体育场举行,学校校长郭禹彤出席动员大会,并强调注意事项。 "立正!&qu…

AIGC绘画基础——Midjourney关键词大全+万能公式

距发布MJ初级注册入门教程已有时日,很多粉丝表示很有用,但关键词有很多人不知如何组合使用,那今天再给大家更新一期,主要是教大家如何用关键词、把控关键词描述,除此之外在文末更新了一大堆关键词给大家使用~ 一、Midj…

算法工程师需要学习C++的哪些知识?

在开始前刚好我有一些资料,是我根据网友给的问题精心整理了一份「C的资料从专业入门到高级教程」, 点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!!以下是算法工程师需要学习的一些…

韶关学院携手泰迪智能科技“见习研学”活动圆满结束

为进一步深化校企合作,落实高校应用型人才培养。5月31日,韶关学院与广东泰迪智能科技股份有限公司联合开展学生企业见习活动。专业教师林思思以及来自韶关学院140名学生参与此次见习活动,泰迪智能科技培训业务部经理钟秋平、校企合作经理吴桂…

linux系统getopt_long函数使用

在linux程序中,我们还经常看见使用--标识输入参数的,这种就需要使用getopt_long函数来解析。 如下使用方式: while ((opt getopt_long(argc, argv, short_options, long_options, &option_index)) ! -1) { //...... } 参数longopts结…

【Python入门学习笔记】Python3超详细的入门学习笔记,非常详细(适合小白入门学习)

Python3基础 想要获取pdf或markdown格式的笔记文件点击以下链接获取 Python入门学习笔记点击我获取 1,Python3 基础语法 1-1 编码 默认情况下,Python 3 源码文件以 UTF-8 编码,所有字符串都是 unicode 字符串。 当然你也可以为源码文件指…

VSCode编译C++代码

1. 自定义编译 主要通过 设置任务(动作)来实现。 tasks.json文件相当于vscode的.sh或.bat文件,用来记录一系列操作的宏。 一系列动作,那就可以用来设置 如何编译文件,如何 运行文件,几乎.sh能干的都可以干…

三维地图校内导航系统解决方案

在如今的数字化时代,越来越多的学校开始实施智慧校园计划,旨在为学生和教师提供更高效、便捷的学习和教学环境。智慧校园运用互联网、大数据、人工智能等技术,对校园内各信息进行收集、整合、分析和应用,实现教学、管理、服务等多…

python-旋转字符串

问题描述:给定一个字符串(以字符串数组的形式)和一个偏移量,根据偏移量从左到右地旋转字符数组。 问题示例:输入str”abcdefg”,offset3,输出“efgabcd”。输入str”abcdefg”,offset0,输出“abcdefg”。(返…

深度解析:速卖通618风控下自养号测评的技术要点

速卖通每年的618大促活动平台的风控都会做升级,那相对的测评技术也需要进行相应的做升级,速卖通618风控升级后,自养号测评需要注意以下技术问题,以确保测评 的稳定性和安全性: 一、物理环境 1. 硬件参数伪装&#x…

Linux 36.3 + JetPack v6.0@jetson-inference之目标检测

Linux 36.3 JetPack v6.0jetson-inference之目标检测 1. 源由2. detectnet2.1 命令选项2.2 下载模型2.3 操作示例2.3.1 单张照片2.3.2 多张照片2.3.3 视频 3. 代码3.1 Python3.2 C 4. 参考资料 1. 源由 从应用角度来说,目标检测是计算机视觉里面第二个重要环节。之…

商家转账到零钱功能千次开通操作分享

小程序地理位置接口有什么功能? 通常在申请开通getLocation 接口被驳回,驳回理由“申请的接口因提供的申请原因/辅助图片/网页/视频内容/无法确认申请接口使用场景”。原因是没有准确提供在那个场景调取地图定位功能,可以按以下步骤提供使用地…

AI预测福彩3D采取888=3策略+和值012路一缩定乾坤测试6月3日预测第10弹

昨天的第二套方案再次成功命中!今天继续基于8883的大底,使用尽可能少的条件进行缩号。好了,直接上结果吧~ 首先,888定位如下: 百位:7,6,8,5,9,2,1,0 十位:6,7,8,5,9,…