【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;


}
相关推荐
YuanDaima20481 分钟前
图论基础原理与题目说明
数据结构·人工智能·python·算法·图论·手撕代码
AI人工智能+电脑小能手1 分钟前
【大白话说Java面试题 第53题】【JVM篇】第13题:JVM采用什么算法判断一个对象是否需要被回收?
java·jvm·算法·面试
小赵不会秃头6 分钟前
数据结构Day 06:线性结构、库操作及 Makefile 完整学习笔记
java·linux·数据结构·算法·面试
Shan120516 分钟前
在C++中尝试封装为函数
开发语言·c++·算法
郝学胜-神的一滴27 分钟前
干货版《算法导论》04:渐近复杂度与序列接口实战
java·开发语言·数据结构·c++·python·算法
zzzsde27 分钟前
【Linux】信号处理(3)信号处理&&valatile关键字
linux·运维·服务器·开发语言·算法
洛水水41 分钟前
【力扣100题】47.最长递增子序列
算法·leetcode·职场和发展
环流_1 小时前
Redis zinterstore
算法
不知名的忻1 小时前
交换排序:冒泡排序 vs 快速排序(Java)
java·算法·排序算法
沃普天科技1 小时前
USB显示器多屏异显多屏拼接IF8032 IT690 VL171 8801 RTD2556
arm开发·驱动开发·算法·计算机外设·音视频·硬件工程·pcb工艺