LeetCode题解:2487. 从链表中移除节点,递归

Problem: 2487. 从链表中移除节点

思路

这个问题要求我们移除链表中每个右侧有一个更大数值的节点。解决方案采用递归的方法,从链表的末尾开始向前处理,每次查看相邻两个节点的大小关系,将不符合要求的节点移除。

解题方法

  1. 递归基础:如果当前节点为空,直接返回它。这是递归的终止条件。
  2. 递归处理:对当前节点的下一个节点调用递归函数,以处理链表的剩余部分。
  3. 节点比较:比较当前节点和它的下一个节点的值。如果当前节点的值小于下一个节点的值,意味着当前节点应该被移除。
  4. 返回结果:根据比较结果,返回适当的节点作为新的链表头。

复杂度

时间复杂度:
O ( n ) O(n) O(n)

空间复杂度:
O ( n ) O(n) O(n)

Code

/**
 * Definition for singly-linked list.
 * function ListNode(val, next) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 * }
 */
/**
 * @param {ListNode} head
 * @return {ListNode}
 */
var removeNodes = function(head) {
  // 递归终止条件
  if (!head) {
    return head
  }
  
  // 递归处理链表的剩余部分
  head.next = removeNodes(head.next)

  // 比较当前节点与下一个节点的值
  if (head.next !== null && head.val < head.next.val) {
    return head.next // 移除当前节点
  } else {
    return head // 保留当前节点
  }
};
/**
 * 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 removeNodes(ListNode head) {
      // 递归终止条件
      if (head == null) {
        return head;
      }

      // 递归处理链表的剩余部分
      head.next = removeNodes(head.next);

      // 比较当前节点与下一个节点的值
      if (head.next != null && head.val < head.next.val) {
        return head.next; // 移除当前节点
      } else {
        return head; // 保留当前节点
      }
    }
}
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def removeNodes(self, head: Optional[ListNode]) -> Optional[ListNode]:
      # 递归终止条件
      if not head:
        return head
      
      # 递归处理链表的剩余部分
      head.next = self.removeNodes(head.next)

      # 比较当前节点与下一个节点的值
      if head.next and head.val < head.next.val:
        return head.next # 移除当前节点
      else:
        return head # 保留当前节点
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值