【LeetCode】206. 反转链表

题目

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

https://leetcode.cn/problems/reverse-linked-list/description/

思路

头插法

原地反转方法(空间O(1))

code

java 复制代码
//头插法
class Solution {
    public ListNode reverseList(ListNode head) {
        if(head== null) return null;
        ListNode cur=head;
        ListNode dummy= new ListNode(0, null);//反转链表的dummy
        ListNode oldNode=null;
        while(cur!=null){
		    // 创建新节点,值为cur.val,next指向之前创建的节点
		    ListNode newNode = new ListNode(cur.val, oldNode);
		    
		    // 让虚拟头节点指向最新创建的节点
		    dummy.next = newNode;
		    
		    // 更新oldNode为当前新节点
		    oldNode = newNode;
		    
		    // 移动原链表指针
		    cur = cur.next;
        }
        return dummy.next;
    }
}
java 复制代码
//原地反转
public ListNode reverseList(ListNode head) {
    ListNode prev = null;
    ListNode cur = head;
    while(cur != null) {
     	 ListNode next = cur.next;  // 保存下一个节点(防止链表断裂)
        cur.next = prev;           // 反转:当前节点指向前一个节点
        prev = cur;                // prev移动到当前节点
        cur = next;                // cur移动到下一个节点
    }
    return prev;


}
相关推荐
小宋加油啊2 小时前
机械臂抓取物体 PVN3D算法调研学习
学习·算法·3d
lqqjuly2 小时前
前沿算法深度解析(一)
算法
小欣加油2 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
happymaker06265 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊5 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
努力努力再努力wz7 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂7 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录7 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
啦啦啦啦啦zzzz7 小时前
算法总结(二分查找、双指针)
c++·算法