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

Java数据结构 (链表反转(LinkedList----Leetcode206))

 

1. 链表的当前结构

  • 每个方框代表一个节点,每个节点包含两个部分:
    • 左侧的数字:节点存储的值,例如 4534 等。
    • 右侧的地址(如 0x90):表示该节点 next 指针指向的下一个节点的内存地址。
  • 例子中,链表从右向左依次连接,形成 45 -> 34 -> 23 -> 12
初始结构
  • 链表的头节点为 12head 指向 12
  • cur:当前节点,指向某个正在操作的节点。

2. 代码逻辑解读

head.next = null; // 第一步
cur.next = head;
head = cur;
cur = curN;

代码功能

  1. head.next = null;

    • 将原链表的 headnext 置为 null,这是反转的关键一步,因为反转后,原来的头节点将变成尾节点。
  2. cur.next = head;

    • 将当前节点 curnext 指向 head
    • 这样,当前节点 cur 插入到新链表的头部。
  3. head = cur;

    • 更新头节点为 cur,当前节点变成了新链表的头部。
  4. cur = curN;

    • cur 更新为下一个节点 curN,继续处理链表的剩余部分。

3. 图示解析

  • 初始状态

  • 完整代码:

    public ListNode reverseList(ListNode head) {
        ListNode cur = head;  // 当前节点
        ListNode curN;        // 下一个节点
        head = null;          // 初始化新链表的头部为空
        
        while (cur != null) {
            curN = cur.next;  // 保存下一个节点的位置
            cur.next = head;  // 当前节点指向新链表的头部
            head = cur;       // 更新新链表的头部
            cur = curN;       // 移动到下一个节点
        }
        return head;
    }
    

    5. 反转链表的特点

  • 时间复杂度O(n),每个节点只处理一次。
  • 空间复杂度O(1),只使用了固定的指针变量 curcurN
  • 应用场景
    • 需要逆序访问链表时(如回文检查)。
    • 数据倒序排列。

反转链表原理(Java实现)_哔哩哔哩_bilibili


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

相关文章:

  • 读书笔记--分布式服务架构对比及优势
  • 基于Django的豆瓣影视剧推荐系统的设计与实现
  • 【ComfyUI专栏】推荐几个常用的云端ComfyUI平台
  • Jetson Xavier NX (ARM) 使用 PyTorch 安装 Open3D-ML 指南
  • 【Leetcode 每日一题】40. 组合总和 II
  • git gui 笔记
  • Qt网络通信(TCP/UDP)
  • 运维实战---多种方式在Linux中部署并初始化MySQL
  • DeepSeek_R1论文翻译稿
  • RV1126画面质量五:Profile和编码等级讲解
  • 【北京大学 凸优化】Lec1 凸优化问题定义
  • Linux Futex学习笔记
  • 第 10 课 Python 内置函数
  • 在 Ubuntu22.04 上安装 Splunk
  • 2025年1月22日(什么是扫频)
  • vue router路由复用及刷新问题研究
  • 从 VJ 拥塞控制到 BBR:ACK 自时钟和 pacing
  • 《Kotlin核心编程》上篇
  • 【动态规划】杨表
  • YOLOv11改进,YOLOv11检测头融合DSConv(动态蛇形卷积),并添加小目标检测层(四头检测),适合目标检测、分割等任务
  • SQL注入漏洞之SQL注入基础知识点 如何检测是否含有sql注入漏洞
  • 【leetcode100】二叉树的层序遍历
  • Elasticsearch中的度量聚合:深度解析与实战应用
  • mock可视化生成前端代码
  • javascript-es6 (一)
  • 【Vim】Vim 中将文件内容复制到系统剪切板的方法