当前位置: 首页 > news >正文

【数据结构OJ题】链表的回文结构

原题链接:https://www.nowcoder.com/practice/d281619e4b3e4a60a2cc66ea32855bfa?tpId=49&&tqId=29370&rp=1&ru=/activity/oj&qru=/ta/2016test/question-ranking

目录

1. 题目描述

2. 思路分析

3. 代码实现


1. 题目描述

 

2. 思路分析

在做这道题之前,我们首先得知道什么是“回文”。

回文就是指正读和反读都相同的字符序列为“回文”,如“abba”、“abccba”、12321123321是“回文”,“abcde”和“ababab”则不是“回文”。

知道了回文的意思后,我们开始分析题目!

先找到中间结点,然后把后半部分逆置,最后对前后两部分一一比对如果结点的值全部相同,则即为回文否则就不是回文

如果链表是回文结构如下图(左半部分为奇数个结点的情况,右半部分为偶数个结点的情况)

如果有小伙伴不知道怎么求链表的中间结点,可以看看这篇文章:

https://blog.csdn.net/m0_62531913/article/details/132309395?spm=1001.2014.3001.5502

如果有小伙伴不知道怎么将链表逆置,可以看看这篇文章:

https://blog.csdn.net/m0_62531913/article/details/132297310?spm=1001.2014.3001.5502

3. 代码实现

/*
struct ListNode {int val;struct ListNode *next;ListNode(int x) : val(x), next(NULL) {}
};*/
class PalindromeList {
public:struct ListNode* middleNode(struct ListNode* head){struct ListNode *slow=head,*fast=head;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;}return slow;}struct ListNode* reverseList(struct ListNode* head){struct ListNode *n1,*n2,*n3;n1=NULL;n2=head;if(n2)n3=n2->next;while(n2){n2->next=n1;n1=n2;n2=n3;if(n3)n3=n3->next;}return n1;}bool chkPalindrome(ListNode* head) {struct ListNode* mid=middleNode(head);struct ListNode* rmid=reverseList(mid);while(head&&rmid){if(head->val!=rmid->val){return false;}else{head=head->next;rmid=rmid->next;}}return true;}
};

 

http://www.lryc.cn/news/127626.html

相关文章:

  • Nginx常见的三个漏洞
  • 爬虫逆向实战(十六)--某建筑市场平台
  • 用Python做一个滑雪小游戏
  • EXCEL按列查找,最终返回该列所需查询序列所对应的值,VLOOKUP函数
  • java编译报错,get方法报错
  • 可以降低CPU负载的网络传输技术——LSO
  • [管理与领导-25]:IT基层管理者 - 团队管理 - 如何留人, 如何留住关键人才
  • 【Redis】Redis 的学习教程(二)之 Jedis
  • VB+SQL银行设备管理系统设计与实现
  • Python系统学习1-9-类一之类语法
  • PHP“深入浅出”淘宝商品详情数据接口获取方法,淘宝API申请指南
  • 线性代数再回顾
  • (白帽黑客)自学笔记
  • 基于长短期神经网络的客流量预测,基于长短期神经网络的超短期客流量预测,lstm详细原理
  • 前端文件下载通用方法
  • htmlCSS-----案例展示
  • Android进阶之路 - 去除EditText内边距
  • ModStartCMS v7.0.0 多语言开发优化,多个常用组件升级
  • 一百五十八、Kettle——Kettle各版本及其相关安装包分享(网盘链接,不需积分、不需验证码) 持续更新、持续分享
  • 【通俗易懂】如何使用GitHub上传文件,如何用git在github上传文件
  • 计算机视觉之三维重建(二)(摄像机标定)
  • PHP面向对象面试题
  • 6G 特点及表现
  • 【Git】(一)基本操作
  • Github下载任意版本的VsCode
  • ThreadLocal(超详细介绍!!)
  • stable diffusion安装包和超火使用文档,数字人制作网址
  • JVM——HotSpot的算法细节实现
  • 高等数学教材重难点题型总结(三)微分中值定理和导数的应用
  • 神经网络基础-神经网络补充概念-39-梯度消失与梯度爆炸