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

OR36 链表的回文结构 题解

题目描述:链表的回文结构_牛客题霸_牛客网 (nowcoder.com)

对于一个链表,请设计一个时间复杂度为O(n),额外空间复杂度为O(1)的算法,判断其是否为回文结构。

给定一个链表的头指针A,请返回一个bool值,代表其是否为回文结构。保证链表长度小于等于900

测试样例:

1->2->2->1       返回:true

题解思路:

  1. 找到中间节点;
  2. 在利用翻转链表的方法,将以中间节点(newList)为新的头节点来翻转链表;
  3. 通过遍历比较两个链表的各个值:如果对应有一个节点的数值不相等,就返回false;如果所以节点的数值都相等,就返回ture。

代码:

struct ListNode* midNode(ListNode* head)
{struct ListNode* fast = head, *slow = head;while(fast && fast->next){fast = fast->next->next;slow = slow->next;}return slow;
}struct ListNode* reverseList(struct ListNode* head)
{struct ListNode* n1 = NULL, *n2 = head, *n3 = head->next;while(n2 != NULL){n2->next = n1;n1 = n2;n2 = n3;if(n3 != NULL){n3 = n3->next;}}return n1;
}
bool chkPalindrome(ListNode* A) {// 找到中间节点struct ListNode* mid = midNode(A);// 翻转链表struct ListNode* newHead = reverseList(mid);// 比较struct ListNode* cur1 = A, *cur2 = newHead;while(cur1 && cur2){if(cur1->val != cur2->val){return false;}else {cur1 = cur1->next;cur2 = cur2->next;}}return true;}

 

注:

如果你还想知道回文数是如何判断的可以看一下,这一篇博客:http://t.csdn.cn/giq9u

翻转链表方法详细解释:http://t.csdn.cn/BLwnA

找链表中间节点:http://t.csdn.cn/uYTNe


本次内容到此结束了!如果你觉得这篇博客对你有帮助的话 ,希望你能够给我点个赞,鼓励一下我。感谢感谢……

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

相关文章:

  • “去没有天花板的地方” | 小红书用户情绪数据
  • Java文件操作(遍历目录中的文件,找到并删除有指定关键字的文件)
  • MySQL单表查询
  • 苹果正在测试新款Mac mini:搭载M3芯片 配备24GB大内存
  • redis的缓存更新策略以及如何保证redis与数据库的数据一致性
  • k8s--使用cornJob定时执行sql文件
  • Qt事件过滤器
  • Java基础集合框架学习(上)
  • 北京多铁克FPGA笔试题目
  • 从初学者的角度来理解指针常量和常量指针
  • C# OpenCvSharp 去水印 图像修复
  • 考研算法第40天:众数 【模拟,简单题】
  • MySQL:内置函数、复合查询和内外连接
  • 【HTML】label 标签
  • python视频流截图(按帧数)
  • MongoDB SQL
  • node js连接mysql数据库
  • 通过Python模拟计算附近WIFI密码,没有我蹭不到的网
  • ubuntu20.04 远程桌面配置记录【亲测好用】
  • 解决selenium的“can‘t access dead object”错误
  • Docker Dockerfile 使用方法
  • (6)(6.3) 复合连接的故障处理
  • 报考红帽认证难不,红帽认证考试容易吗?
  • 如何优雅地用VS编写C#代码——快捷键的使用
  • 微服务——操作索引库+文档操作+RestClient操作索引库和文档(java程序)
  • 【性能测试】性能数据采集工具nmon安装使用及报告参数含义详解
  • 『PostgreSQL』在 PostgreSQL中创建只读权限和读写权限的账号
  • 基于Java+SpringBoot+Vue的网上书城管理系统设计与实现(源码+LW+部署文档等)
  • 安全渗透——AWK知识整理
  • 计算机视觉的应用9-视觉领域中的61个经典数据集【大集合】的应用与实战