前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >反转单链表

反转单链表

作者头像
每周聚焦
发布2025-02-20 11:40:36
发布2025-02-20 11:40:36
6400
代码可运行
举报
运行总次数:0
代码可运行

反转链表的思路

要反转单链表,基本思路是遍历链表的同时改变每个节点的 next 指针的方向,使得每个节点指向它的前驱节点而不是后继节点。由于这是一个单向链表,你需要在改变指针方向之前保存当前节点的下一个节点,以便继续遍历。

迭代法
  1. 初始化
    • 创建三个指针变量:prev(前一个节点),curr(当前节点),next_node(下一个节点)。
    • prev 初始化为 Nonecurr 初始化为链表的头节点 head
  2. 遍历链表
    • 在遍历过程中,对于每个节点,先保存它的下一个节点 (next_node = curr.next)。
    • 然后将当前节点的 next 指针指向前一个节点 (curr.next = prev)。
    • 更新 prevcurr,使其分别指向当前节点和下一个节点 (prev = currcurr = next_node)。
  3. 结束条件
    • curr 变为 None 时,遍历结束,此时 prev 指向新的头节点。
  4. 返回结果
    • 返回 prev 作为新链表的头节点。
示例代码(Python)
代码语言:javascript
代码运行次数:0
运行
复制
python 代码解读复制代码def reverseList(head: ListNode) -> ListNode: 
    prev = None 
    curr = head 
    while curr is not None: 
        next_node = curr.next # 保存下一个节点 
        curr.next = prev # 反转当前节点的指针 
        prev = curr # 移动到下一个节点 
        curr = next_node 
    return prev # 新的头节点

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 反转链表的思路
    • 迭代法
    • 示例代码(Python)
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档