当前位置: 首页 > news >正文

LeetCode 解题思路 45(Hot 100)

在这里插入图片描述

解题思路:

  1. dp 数组的含义: 在数组中是否存在一个子集,其和为 i。
  2. 递推公式: dp[i] |= dp[i - num]。
  3. dp 数组初始化: dp[0] = true。
  4. 遍历顺序: 从大到小去遍历,从 i = target 开始,直到 i = num。确保每个数只用一次。
  5. 打印 dp 数组

Java代码:

class Solution {public boolean canPartition(int[] nums) {int sum = 0;for (int num : nums)sum += num;if (sum % 2 != 0)return false;int target = sum / 2;boolean[] dp = new boolean[target + 1];dp[0] = true;for (int num : nums) {for (int i = target; i >= num; i--) {dp[i] |= dp[i - num];}}return dp[target];}
}

复杂度分析:

  • 时间复杂度: O(n * target)。
  • 空间复杂度: O(target)。
    在这里插入图片描述

解题思路:

可以使用栈来解决这个问题。核心思想是利用栈来跟踪未匹配的括号的索引。初始化时,栈中压入一个基准索引 -1,用于后续计算有效子串的长度。遍历字符串时:

  • 遇到左括号 ‘(’,将其索引压入栈中。
  • 遇到右括号 ‘)’,弹出栈顶元素。此时:
  • 若栈为空,说明当前右括号无匹配,将当前索引压入栈作为新基准。
  • 若栈不为空,当前有效子串长度为当前索引与栈顶元素的差值,更新最大值。

此方法确保每次弹出栈顶后,栈顶元素即为最近未匹配的左括号或基准点,从而快速计算有效长度。

Java代码:

public class Solution {public int longestValidParentheses(String s) {Deque<Integer> stack = new ArrayDeque<>();stack.push(-1);int maxLen = 0;for (int i = 0; i < s.length(); i++) {char c = s.charAt(i);if (c == '(') {stack.push(i);} else {stack.pop();if (stack.isEmpty()) {stack.push(i);} else {maxLen = Math.max(maxLen, i - stack.peek());}}}return maxLen;}
}

复杂度分析:

  • 时间复杂度: O(n)。
  • 空间复杂度: O(n)。

相关文章:

  • 卷积神经网络的简单实战项目
  • C++ string的使用
  • 隔离端口配置
  • ArcGIS Pro图斑属性自动联动更新-在线卫星底图图斑采集
  • C语言结构体内存对齐使用场景
  • 【区块链】Uniswap之滑点(Slippage)
  • R8周:RNN实现阿尔茨海默病诊断
  • 软件代码签名证书SSL如何选择?
  • NoUniqueKey问题和Regular join介绍
  • UE5 脚部贴地不穿过地板方案
  • C++命名空间
  • USB接口的PCB设计
  • K8S - Helm 入门与实战 - 应用部署与依赖治理
  • Java 8 非对称加密代码示例
  • 《让内容“活”起来:Flutter社交应用瀑布流布局的破界实践》
  • 神经网络中之多类别分类:从基础到高级应用
  • Ollama本地部署大模型指南
  • 2025年国考行测 试卷结构和备考建议
  • uv全功能更新:统一管理Python项目、工具、脚本和环境的终极解决方案
  • ONLYOFFICE 文档 API :新的文档格式支持及配置方法
  • 经济日报:落实落细更加积极的财政政策
  • 媒体:西安62岁男子当街殴打妻子,警方称打人者已被行拘
  • IPO周报|节后首批3只新股本周申购,色谱设备龙头来了
  • 魔都眼|上海环球马术冠军赛收官,英国骑手夺冠
  • 严正交涉!我驻日使馆:如日方采取新的挑衅举动,中方必坚决反制
  • 马上评|提供情绪价值,也是文旅经济的软实力