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;
        }
    }
}
相关推荐
SpongeG23 分钟前
数据结构第三周做题总结_链表
数据结构·算法·链表
everyStudy25 分钟前
前端五种排序
前端·算法·排序算法
小珑也要变强25 分钟前
队列基础概念
c语言·开发语言·数据结构·物联网
醉竺29 分钟前
【高阶数据结构】二叉搜索树的插入、删除和查找(精美图解+完整代码)
数据结构
little redcap2 小时前
第十九次CCF计算机软件能力认证-乔乔和牛牛逛超市
数据结构·c++·算法
muyierfly3 小时前
34.贪心算法1
算法·贪心算法
luthane5 小时前
python 实现average mean平均数算法
开发语言·python·算法
静心问道5 小时前
WGAN算法
深度学习·算法·机器学习
杰九6 小时前
【算法题】46. 全排列-力扣(LeetCode)
算法·leetcode·深度优先·剪枝
manba_6 小时前
leetcode-560. 和为 K 的子数组
数据结构·算法·leetcode