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

leetcode-回文链表

234. 回文链表

在此对比的值,不是节点

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:def isPalindrome(self, head: Optional[ListNode]) -> bool:dummy_head = ListNode(next=head)cur = dummy_head.nextval = []while cur:val.append(cur.val)cur = cur.nextreturn val==val[::-1]

使用快慢指针法找到链表的中点,将后半部分链表反转,最后比较前半部分和反转后的后半部分是否相同。

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:def isPalindrome(self, head: Optional[ListNode]) -> bool:if not head or not head.next:return Truedummy_head = ListNode(next=head)slow, fast = dummy_head, dummy_headwhile fast and fast.next:slow = slow.nextfast = fast.next.nextprev, cur = None, slow.nextwhile cur:tmp = cur.nextcur.next = prevprev = curcur = tmpp1, p2 = dummy_head.next, prevwhile p2:if p1.val != p2.val:return Falsep1 = p1.nextp2 = p2.nextreturn True

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

相关文章:

  • Pinia:一个Vue的状态管理库
  • 2024 Flutter 重大更新,Dart 宏(Macros)编程开始支持,JSON 序列化有救
  • 云计算概述(云计算类型、技术驱动力、关键技术、特征、特点、通用点、架构层次)(二)
  • 物流平台架构设计与实践
  • RedHat8.4安装邮件服务器
  • Linux Shell系列--dirname 去除基本文件名
  • 池化技术的总结
  • H5简约星空旋转引导页源码
  • 前端学习之路(4) vue2和vue3的区别
  • 网络原理-TCP/IP(5)
  • Docker 常用命令详细介绍
  • 10G PON演进到50G PON
  • 智能指针——浅析
  • JAVA后端上传图片至企微临时素材
  • MySQL-----初识
  • [基础IO]文件描述符{重定向/perror/磁盘结构/inode/软硬链接}
  • NAS系统折腾记 – Emby搭建家庭多媒体服务器
  • #从零开始# 在深度学习环境中,如何用 pycharm配置使用 pipenv 虚拟环境
  • Cmake编译Opencv3.3.1遇到有些文件无法下载的错误解决:
  • Python基础知识:Python序列以及序列的索引、切片、相乘和相加
  • 回归预测 | Matlab实现CPO-GRU【24年新算法】冠豪猪优化门控循环单元多变量回归预测
  • 开源项目TARZAN-NAV | 基于springboot的现代化导航网站系统
  • SQL查询数据之多表(关联)查询
  • 常见的web前端开发框架介绍
  • CSS 选择器与相关规则详解
  • 基于springboot的宠物店系统的设计与实现
  • Llama2大模型开源,大模型的Android时代来了?
  • 取出list中指定数量数据操作,操作完了删除这些数据
  • Cocos XR的WebBox实现流程
  • netstat是一个常用的网络工具,用于显示和分析网络连接、路由表以及网络接口等信息。