首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在java中删除链表的最后一个节点?

在Java中删除链表的最后一个节点可以通过以下步骤实现:

  1. 首先,判断链表是否为空。如果链表为空,即头节点为null,则无需进行删除操作,直接返回即可。
  2. 创建两个指针,一个指向当前节点,另一个指向当前节点的前一个节点。初始时,将两个指针都指向链表的头节点。
  3. 使用一个循环遍历链表,直到当前节点的下一个节点为空。在循环中,将前一个节点指针指向当前节点,当前节点指针指向下一个节点。
  4. 当循环结束后,当前节点指针指向链表的最后一个节点,前一个节点指针指向倒数第二个节点。
  5. 将前一个节点的next指针指向null,即删除了最后一个节点。

以下是示例代码:

代码语言:txt
复制
public class ListNode {
    int val;
    ListNode next;
    
    ListNode(int val) {
        this.val = val;
    }
}

public class Solution {
    public ListNode deleteLastNode(ListNode head) {
        if (head == null) {
            return null;
        }
        
        ListNode prev = null;
        ListNode curr = head;
        
        while (curr.next != null) {
            prev = curr;
            curr = curr.next;
        }
        
        if (prev == null) {
            // 链表只有一个节点
            head = null;
        } else {
            prev.next = null;
        }
        
        return head;
    }
}

这段代码中,我们定义了一个ListNode类表示链表节点,其中包含一个值val和一个指向下一个节点的指针next。然后,我们定义了一个Solution类,其中的deleteLastNode方法用于删除链表的最后一个节点。

在该方法中,我们首先判断链表是否为空,如果为空则直接返回null。然后,我们创建两个指针prev和curr,分别指向当前节点和当前节点的前一个节点,初始时都指向链表的头节点。接下来,我们使用一个循环遍历链表,直到当前节点的下一个节点为空,循环中将prev指向curr,curr指向下一个节点。循环结束后,prev指向倒数第二个节点,curr指向最后一个节点。最后,我们根据prev是否为空来判断链表是否只有一个节点,如果是,则将头节点置为null;否则,将prev的next指针指向null,即删除了最后一个节点。最后,返回头节点。

这是一个简单的删除链表最后一个节点的实现方法,适用于单向链表。如果是双向链表,删除最后一个节点的方法类似,只需将prev的next指针指向null,并将最后一个节点的prev指针指向null即可。

腾讯云相关产品和产品介绍链接地址:

  • 云服务器(CVM):https://cloud.tencent.com/product/cvm
  • 云数据库 MySQL 版(CMYSQL):https://cloud.tencent.com/product/cmysql
  • 云原生应用引擎(TKE):https://cloud.tencent.com/product/tke
  • 人工智能平台(AI Lab):https://cloud.tencent.com/product/ailab
  • 物联网开发平台(IoT Explorer):https://cloud.tencent.com/product/iothub
  • 移动推送服务(信鸽):https://cloud.tencent.com/product/tpns
  • 对象存储(COS):https://cloud.tencent.com/product/cos
  • 区块链服务(BCS):https://cloud.tencent.com/product/bcs
  • 腾讯云元宇宙:https://cloud.tencent.com/solution/virtual-universe
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

删除链表节点

题目描述 难度级别:简单 请编写一个函数,使其可以删除某个链表给定(非末尾)节点。传入函数唯一参数为 要被删除节点 。...现有一个链表 -- head = [4,5,1,9],它可以表示为: 示例 1: 输入:head = [4,5,1,9], node = 5 输出:[4,1,9] 解释:给定你链表中值为 5 第二个节点...提示: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。...解题思路 题目中待传递给当前函数实参node,它是链表一个删除节点,然后从链表删除这个节点。...这里因为待传入实参没有完整链表,所以无法获取到之前节点,所以无法修改前一个节点next指向。这时需要是将要删除节点值替换为它一个节点值,之后要删除这个节点next指向为下下一项。

2.4K00

删除链表重复节点.

前言 在一个排序链表,存在重复节点,如何删除链表重复节点并返回删除链表头指针?例如:1->2->3->3->4->4->5,处理后为: 1->2->5。...本文将分享这个问题解决思路与实现代码,欢迎各位感兴趣开发者阅读本文。 常规思路 根据题意,我们可以知道链表元素是排好序。如果节点重复的话,当前节点一定与下一个节点相同。...其次,我们需要创建两个指针: 一个指向当前不重复节点,我们将它命名为pre 一个为搜索指针,用于搜索链表与当前节点不重复节点,我们将它命名为last 随后,我们为 pre 与 last 进行初始赋值...20220226224625702 实现代码 接下来,我们将上述思路转换为代码,如下所示: /** * 删除链表重复节点 * @param pHead 链表节点 */ deleteDuplicatesNode...* * 删除链表重复节点(递归解法) * @param pHead 链表节点 */ deleteDuplicatesNodeForRecursion(pHead: ListNode

2.8K40

237 删除链表节点

01 题目信息 题目地址: https://leetcode-cn.com/problems/delete-node-in-a-linked-list/ 请编写一个函数,使其可以删除某个链表给定(非末尾...传入函数唯一参数为 要被删除节点 。 现有一个链表 -- head = [4,5,1,9],它可以表示为: ?...提示: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。...x) { val = x; } } 现在它传一条链表一个节点删除这个节点。...因为一个节点信息只有自己值以及下个节点。所以传入一个节点是看不到整个链表。也就是说我们只能拿到部分链就是传入节点之后5--->1--->9。

1.3K10

2 删除链表节点

复习链表插入 链表一个节点是由数据域和指针域构成,指针域地址值为下个元素地址。那么我们需要插入或者删除一个元素怎么处理呢? ? 先查看原始链表结构,准备将结点x插入链表。 ?...1 Leetcode237 删除链表节点 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...说明: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。 先思考一分钟哟! 效果更好哈!...仔细看题 发现没,题目并没有告诉我们其上一个结点,不要紧,我们可以想办法构造出一个结点,请看下。 目标还是删除5,最后结果为[4,1,9]。我们把需要删除5结点后面节点1赋值给它,如下图8. ?...3 java版本 ?

1.3K20

Swift 删除链表节点 - LeetCode

LeetCode 题目: 删除链表节点 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...现有一个链表 -- head = 4,5,1,9,它可以表示为: 4 -> 5 -> 1 -> 9 示例1: 输入: head = [4,5,1,9], node = 5 输出: [4,1,9] 解释...: 给定你链表中值为 5 第二个节点,那么在调用了你函数之后,该链表应变为 4 -> 1 -> 9....示例2: 输入: head = [4,5,1,9], node = 1 输出: [4,5,9] 解释: 给定你链表中值为 1 第三个节点,那么在调用了你函数之后,该链表应变为 4 -> 5 -> 9...说明: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。

1.3K40

Leetcode No.237 删除链表节点

一、题目描述 请编写一个函数,使其可以删除某个链表给定(非末尾)节点。传入函数唯一参数为 要被删除节点 。...现有一个链表 head = [4,5,1,9],它可以表示为: 示例 1: 输入:head = [4,5,1,9], node = 5 输出:[4,1,9] 解释:给定你链表中值为 5 第二个节点...二、解题思路 从链表删除一个节点 node 最常见方法是修改之前节点 next 指针,使其指向之后节点。...我们无法访问我们想要删除节点 之前 节点,因此我们始终不能修改该节点 next 指针。 换个思路,我们可以将想要删除节点值替换为它后面节点值,然后删除它之后节点。...因为我们知道要删除节点不是列表末尾,所以我们可以保证这种方法是可行

40440

删除链表节点

题目信息 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...示例 1: 输入: head = [4,5,1,9], node = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 第二个节点,调用函数后,该链表应变为 4 -> 1 -> 9....示例 2: 输入: head = [4,5,1,9], node = 1 输出: [4,5,9] 解释: 给定你链表中值为 1 第三个节点,调用函数后,该链表应变为 4 -> 5 -> 9....说明: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。...解题 只给定了要删除节点,无法得知上一个next指针 直接交换要删节点值与其next存val 删除其next节点即可 /** * Definition for singly-linked

39220

链表问题】删除链表第K个节点

前言 以专题形式更新刷题贴,欢迎跟我一起学习刷题。每道题会提供简单解答。 【题目描述】 在单链表删除倒数第 K 个节点。...【要求】 如果链表长度为 N, 时间复杂度达到 O(N), 额外空间复杂度达到 O(1) 【难度】 士 【解答】 删除时候会出现三种情况: 1、不存在倒数第 K 个节点,此时不用删除。...2、倒数第 K 个节点就是第一个节点。 3、倒数第 K 个节点在第一个节点之后。 所以我们可以用一个变量 num 记录链表一共有多少个节点。 如果 num < K,则属于第一种情况。...如果 num == K,则属于第二情况。 如果 num > K, 则属于第三种情况,此时删除倒数第 K 个节点等价于删除第 (num - k + 1) 个节点。...(num-k+1)个节点 //定位到这个点前驱 while (num - K !

1.7K10

leetcode刷题(8)——删除链表节点

请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...现有一个链表 – head = [4,5,1,9],它可以表示为: 示例 1: 输入: head = [4,5,1,9], node = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 第二个节点...,那么在调用了你函数之后,该链表应变为 4 -> 1 -> 9....示例 2: 输入: head = [4,5,1,9], node = 1 输出: [4,5,9] 解释: 给定你链表中值为 1 第三个节点,那么在调用了你函数之后,该链表应变为 4 -> 5 -...思路: 常规解法肯定是从头开始遍历找到这个节点,但是这样写法是无法通过面试,巧妙解法是将后一个节点复制到当前节点即可,当然这里题目限制了不可能是最后一个节点,否则应该还要增加最后一个节点情况处理

23820

leecode刷题(20)-- 删除链表节点

leecode刷题(20)-- 删除链表节点 删除链表节点 描述: 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...现有一个链表 -- head = [4,5,1,9],它可以表示为: 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...说明: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。...思路: 这道题出很妙,因为从链表删除一个节点 node ,我们最先想到是修改之前节点 next 指针,使其指向之后节点。...我们换种思路,我们将想要删除节点替换为它后面节点值,然后删除它之后节点。这样我们就完成了题目要求删除链表节点

66220

LeetCode 图解 | 237.删除链表节点

下面开始今天学习~ ? 今天分享题目来源于 LeetCode 上第 237 号问题:删除链表节点。...题目描述 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。 现有一个链表 -- head = [4,5,1,9],它可以表示为: ?...说明: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。...之前删除一个节点方法是要有其前一个节点位置,然后将其前一个节点 next连向要删节点一个,然后 delete 掉要删节点即可。...相关题目推荐 LeetCode 26:删除排序数组重复项 LeetCode 203:移除链表元素

28010
领券