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

LeetCode 解题思路 12(Hot 100)

在这里插入图片描述

解题思路:

  1. 定义三个指针: prev(前驱节点)、current(当前节点)、nextNode(临时保存下一个节点)
  2. 遍历链表: 每次将 current.next 指向 prev,移动指针直到 current 为 null。

Java代码:

public class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode prev = null;
        ListNode current = head;
        while (current != null) {
            ListNode nextNode = current.next;
            current.next = prev;
            prev = current;
            current = nextNode;
        }
        return prev;
    }
}

复杂度分析:

  • 时间复杂度: O(n),需要遍历所有节点一次。
  • 空间复杂度: O(1),仅使用固定数量的额外空间。

在这里插入图片描述

解题思路:

  1. 找中点: 使用快慢指针,快指针每次移动两步,慢指针每次移动一步,直到快指针到达末尾。此时慢指针位于链表中点。
  2. 反转后半部分: 将中点之后的链表部分反转。
  3. 对称比较: 从头节点和中点开始,逐个比较对应节点的值是否相等。

Java代码:

public class Solution {
    public boolean isPalindrome(ListNode head) {
        if (head == null || head.next == null) return true;

        ListNode slow = head, fast = head.next;
        while (fast != null && fast.next != null) {
            fast = fast.next.next;
            slow = slow.next;
        }

        ListNode prev = null, curr = slow.next;
        while (curr != null) {
            ListNode nextNode = curr.next;
            curr.next = prev;
            prev = curr;
            curr = nextNode;
        }

        ListNode p1 = head, p2 = prev;
        while (p2 != null) {
            if (p1.val != p2.val) return false;
            p1 = p1.next;
            p2 = p2.next;
        }
        return true;
    }
}

复杂度分析:

  • 时间复杂度: O(n),所有操作均遍历链表一次。
  • 空间复杂度: O(1),仅使用常数额外空间。

http://www.kler.cn/a/576796.html

相关文章:

  • .NET Core全屏截图,C#全屏截图
  • C++蓝桥杯基础篇(八)
  • python爬虫系列课程6:js定时器
  • Python SQLite3 保姆级教程:从零开始学数据库操作
  • MYSQL之创建数据库和表
  • 队列相关练习
  • springboot多模块项目中IDEA报错找不到符号
  • 基于51单片机的六路抢答器proteus仿真
  • DeepSeek的安全威胁与国际象棋水平测试
  • 云计算:虚拟化、容器化与云存储技术详解
  • FPGA之USB通信实战:基于FX2芯片的Slave FIFO回环测试详解
  • 【CVPR2025】 EVSSM:用状态空间模型高效去模糊
  • 基于粒子群算法的配电网重构
  • 中性点不接地系统单相接地故障Matlab仿真
  • python 使用flask+sqlalchemy 实现简单数据查询接口
  • 【江协科技STM32】ADC数模转换器-学习笔记
  • MWC2025|5G与AI的深度融合势不可挡,赛思高精度时钟同步为其筑基!
  • 如何在Ubuntu上直接编译Apache Doris
  • 小方摄像头接入本地服务器的方法
  • 深入剖析MyBatis缓存机制:原理、源码与实战指南