【每日一题】LeetCode206.反转链表

个人主页:白日依山璟

专栏:Java|数据结构与算法|每日一题

文章目录

1. 题目描述

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

示例1

输入:head = 1,2,3,4,5

输出:5,4,3,2,1

示例2

输入:head = 1,2

输出:2,1

示例3

输入:head =

输出:

提示

  • 链表中节点的数目范围是[0,500]
  • -5000 <= Node.val <= 5000

题目链接

2. 思路

  1. 判断链表是否为空,如果为空直接返回头结点

  2. 判断链表是否为一个元素,如果是直接返回头结点

  3. headnext置为null

  4. 定义两个指针,curcurNextcur 指向头结点的next,表示要反转的元素;curNext指向curnext,表示要反转元素的下一个元素

  5. 使用头插法将要反转的元素插入前一个元素的前面

3.代码

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) {
        if (head == null) { // 链表里一个元素都没有
            return head;
        }
        if (head.next == null) { // 链表里只有一个元素
            return head;
        }

        ListNode cur = head.next; // 要反转的元素
        head.next = null;

        while (cur != null) {
            ListNode curNext = cur.next;
            // 头插法
            cur.next = head;
            head = cur;
            cur = curNext;
        }
        return head;
    }
}

运行结果:

世界上有三种k,梅花k,方片k,还有任何人不关注我我都会难过的ok

相关推荐
壹号用户6 小时前
C++入门(引用)
数据结构·c++
lcj25116 小时前
【list】手撕C++ list!从0到1实现双向链表,迭代器、const迭代器、模板全解析,面试官都惊呆了!
c++·笔记·链表·list
fengxin_rou6 小时前
leetcode二维数组高频面试题详解:48.原地旋转矩阵 + 240.杨氏矩阵查找算法深度剖析
数据结构·leetcode·java 算法·面试算法
05候补工程师6 小时前
【408 数据结构】图论核心算法(拓扑/关键路径)与二叉搜索树精髓夺分笔记
数据结构·经验分享·笔记·考研·算法·图论
迈巴赫车主7 小时前
Prim堆优化
数据结构·算法·prim
郝学胜-神的一滴7 小时前
干货版《算法导论》08:哈希——重构集合数据结构的速度魔法
数据结构·python·程序人生·算法·重构·软件构建·哈希算法
apcipot_rain7 小时前
计科八股20260605——软件生命周期、文档、死锁、地址转换、I/O控制方式、堆、无向图、连通图、最小支配集、逆关系、永真式
数据结构·操作系统·软件工程·计算机组成原理·离散数学
洒脱的六边形战士加辣7 小时前
Java排序方法全解析
java·数据结构·算法
代码中介商8 小时前
LRU缓存算法:双向链表+哈希表实现
算法·链表·缓存
hope_wisdom8 小时前
C/C++数据结构之二叉树基础
c语言·数据结构·c++·二叉树