2487. 从链表中移除节点 --力扣 --JAVA

题目

给你一个链表的头节点 head

移除每个右侧有一个更大数值的节点。

返回修改后链表的头节点head

解题思路

  1. 移除每个右侧有一个更大数值的节点,所以可以利用深度遍历,从后往前进行比较;
  2. 创建变量max来表示当前右侧的最大值;
  3. 将最后节点的值赋值给max;
  4. 若当前节点的值小于当前节点则移除,否则修改max为当前节点的值,链表是单向的,直接移除当前节点不好移除,可以将下个节点的值和next赋值给当前节点,即用下个节点取代当前节点。

代码展示

java 复制代码
class Solution {
    private int max = 0;
    public ListNode removeNodes(ListNode head) {
        dfs(head);
        return head;
    }
    private void dfs(ListNode root){
        if(root == null){
            return;
        }
        dfs(root.next);
        if(root.val < max){
            root.val = root.next.val;
            root.next = root.next.next;
        } else {
            max = root.val;
        }
    }
}
相关推荐
Univin3 小时前
C++(10.4)
开发语言·数据结构·c++
KyollBM3 小时前
每日羊题 (质数筛 + 数学 | 构造 + 位运算)
开发语言·c++·算法
Univin5 小时前
C++(10.5)
开发语言·c++·算法
Asmalin5 小时前
【代码随想录day 35】 力扣 01背包问题 一维
算法·leetcode·职场和发展
剪一朵云爱着5 小时前
力扣2779. 数组的最大美丽值
算法·leetcode·排序算法
qq_428639615 小时前
虚幻基础:组件间的联动方式
c++·算法·虚幻
深瞳智检6 小时前
YOLO算法原理详解系列 第002期-YOLOv2 算法原理详解
人工智能·算法·yolo·目标检测·计算机视觉·目标跟踪
怎么没有名字注册了啊6 小时前
C++后台进程
java·c++·算法
Rubisco..7 小时前
codeforces 2.0
算法
未知陨落7 小时前
LeetCode:98.颜色分类
算法·leetcode