【每日一题】LeetCode——反转链表

在这里插入图片描述

📚博客主页:爱敲代码的小杨.

✨专栏:《Java SE语法》 | 《数据结构与算法》 | 《C生万物》

❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️

🙏小杨水平有限,欢迎各位大佬指点,相互学习进步!


1. 题目描述

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

示例1

img

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

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

示例2

img

输入:head = [1,2]

输出:[2,1]

示例3

输入:head = [ ]

输出:[ ]

提示

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

题目链接

2. 思路

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

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

  3. head置为null

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

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

    image-20231218095202374

3.代码

/**
 * 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;
    }
}

运行结果:

image-20231218093949377

相关推荐

  1. leetcode-

    2024-02-09 20:28:01       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-09 20:28:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-09 20:28:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-09 20:28:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-09 20:28:01       18 阅读

热门阅读

  1. shell脚本之无限计时器

    2024-02-09 20:28:01       28 阅读
  2. c++小游戏整理

    2024-02-09 20:28:01       24 阅读
  3. C语言——oj刷题——实现字符串逆序

    2024-02-09 20:28:01       29 阅读
  4. OpenVPN简记

    2024-02-09 20:28:01       25 阅读
  5. Python循环语句——for循环临时变量作用域

    2024-02-09 20:28:01       32 阅读