后端开发刷题 | 反转链表【链表篇】

描述

给定一个单链表的头结点pHead(该头节点是有值的,比如在下图,它的val是1),长度为n,反转该链表后,返回新链表的表头。

数据范围: 0≤n≤1000

要求:空间复杂度 O(1)O(1) ,时间复杂度 O(n)O(n) 。

如当输入链表{1,2,3}时,

经反转后,原链表变为{3,2,1},所以对应的输出为{3,2,1}。

以上转换过程如下图所示:

示例1

输入:

复制代码
{1,2,3}

返回值:

复制代码
{3,2,1}

示例2

输入:

复制代码
{}

返回值:

复制代码
{}

说明:

复制代码
空链表则输出空        

思路:

代码:

java 复制代码
import java.util.*;
 

public class Solution {
    /**
     *
     * 
     * @param head ListNode类 
     * @return ListNode类
     */
    public ListNode ReverseList (ListNode head) {
        if(head==null){
            return null;
        }
        ListNode pre=null;
        ListNode next=null;
        while(head!=null){
            next=head.next;
            head.next=pre;
            pre=head;
            head=next;
        }

        return pre;

    }
}
相关推荐
ModestCoder_6 分钟前
Tokenization的演进:从NLP基石到多模态AI的“通用翻译器”
开发语言·人工智能·自然语言处理·机器人·具身智能
小虾米 ~6 分钟前
RocketMQ DefaultMQPushConsumer vs DefaultLitePullConsumer
java·rocketmq·java-rocketmq
q***21608 分钟前
【监控】spring actuator源码速读
java·spring boot·spring
Kuo-Teng19 分钟前
LeetCode 142: Linked List Cycle II
java·算法·leetcode·链表·职场和发展
Moe48825 分钟前
ConcurrentHashMap 重要方法实现原理和源码解析(一)
java·后端
hweiyu0025 分钟前
GO的优缺点
开发语言·后端·golang
大橙子打游戏27 分钟前
在Xcode里自由使用第三方大模型?这个本地代理工具帮你实现!
后端
ada7_30 分钟前
LeetCode(python)——73.矩阵置零
python·算法·leetcode·矩阵
h***346337 分钟前
Nginx 缓存清理
android·前端·后端
小龙报41 分钟前
《算法通关指南C++编程篇 --- 初阶函数递归专题》
c语言·开发语言·c++·算法·创业创新·学习方法·visual studio