(leetcode)力扣100 23反转链表(迭代||递归)

题目

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

数据范围

链表中节点的数目范围是 [0, 5000]

-5000 <= Node.val <= 5000

测试用例

示例1

java 复制代码
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

示例2

java 复制代码
输入:head = [1,2]
输出:[2,1]

示例3

java 复制代码
输入:head = []
输出:[]

题解1(时间On空间O1)

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode pre=null;
        ListNode cur=head;
        while(cur!=null){
            ListNode next= cur.next ;
            cur.next=pre;
            pre=cur;
            cur=next;    
        }
        return pre;
    }
}

题解2(时空On)

java 复制代码
    public ListNode reverseList(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        ListNode newHead = reverseList(head.next);
        head.next.next = head;
        head.next = null;
        return newHead;
    } }

`
## 思路
这道题感觉没必要讲啥思路了,最经典最基础数据结构链表翻转的两个方法,能理解就好,不能理解背就完了!!
相关推荐
SatVision炼金士4 分钟前
合成孔径雷达干涉测量(InSAR)沉降监测算法体系
算法
wuweijianlove8 分钟前
算法稳定性与数值误差传播研究的技术2
算法
计算机安禾31 分钟前
【数据结构与算法】第35篇:归并排序与基数排序
c语言·数据结构·vscode·算法·排序算法·哈希算法·visual studio
爱码小白42 分钟前
MySQL 单表查询练习题汇总
数据库·python·算法
橘颂TA44 分钟前
【笔试】算法的暴力美学——牛客 NC213140 :除2!
c++·算法·结构与算法
汀、人工智能1 小时前
[特殊字符] 第66课:跳跃游戏
数据结构·算法·数据库架构·图论·bfs·跳跃游戏
汀、人工智能1 小时前
[特殊字符] 第70课:加油站
数据结构·算法·数据库架构·图论·bfs·加油站
wsoz1 小时前
Leetcode普通数组-day5、6
c++·算法·leetcode·数组
y = xⁿ1 小时前
【LeetCode】双指针:同向快慢针
算法·leetcode
啊哦呃咦唔鱼1 小时前
LeetCode hot100-105从前序与中序遍历序列构造二叉树
算法