2025-3-23 leetcode刷题情况(动态规划)

一、343.整数拆分

1.题目描述

给定一个正整数n,将其拆分为k个正整数 的和(k>=2),并使这些整数的乘积最大化。

返回 你可以获得的最大乘积。

2.代码

3.思路

首先创建一个长度为n + 1的数组dp用于存储每个正整数拆分后的最大乘积,初始化dp[2]为 1 。接着从 3 开始遍历到n,对于每个数i,再遍历从 1 到i - j的数j,考虑两种拆分情况:一是直接将i拆分为ji - j,计算它们的乘积;二是将i拆分为j和可继续拆分的i - j,用j乘以dp[i - j]。取这两种情况的最大值,并更新dp[i]。最终返回dp[n],即n拆分后的最大乘积。

二、96.不同的二叉搜索树

1.题目描述

给你一个整数 n,求恰由 n个节点组成且节点值从 1 到 n互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。

2.代码

3.思路

首先创建长度为 n + 1 的数组 dp 存储结果,初始化 dp[0]dp[1] 为 1,分别代表空树和单节点树的情况。接着从 2 到 n 遍历节点数 i,对于每个 i,再从 1 到 i 遍历以不同节点 j 为根的情况。以 j 为根时,左子树有 j - 1 个节点,右子树有 i - j 个节点,根据乘法原理,以 j 为根的不同二叉搜索树数量是 dp[j - 1]dp[i - j] 的乘积,将这些乘积累加更新 dp[i],最终返回 dp[n] 作为结果。

相关推荐
过河卒_zh156676615 分钟前
情感型AI被“立规矩”,AI陪伴时代进入下半场
人工智能·算法·aigc·生成式人工智能·算法备案
wefg125 分钟前
【算法】动态规划
算法·动态规划
机器学习之心34 分钟前
198种组合算法+优化TCN-Transformer+SHAP分析+新数据预测+多输出!深度学习可解释分析,强烈安利,粉丝必备!
深度学习·算法·transformer·shap分析·新数据预测
狐5735 分钟前
2026-01-12-LeetCode刷题笔记-1266-访问所有点的最小时间.md
笔记·算法·leetcode
Gorgous—l35 分钟前
数据结构算法学习:LeetCode热题100-栈篇(有效的括号、最小栈、字符串解码、每日温度、柱状图中最大的矩形)
数据结构·学习·算法
小郭团队37 分钟前
教育公平的探索
大数据·人工智能·嵌入式硬件·算法·硬件架构
瑞雨溪41 分钟前
力扣题解:740.删除并获得点数
算法·leetcode·职场和发展
LeeeX!43 分钟前
基于YOLO11实现明厨亮灶系统实时检测【多场景数据+模型训练、推理、导出】
深度学习·算法·目标检测·数据集·明厨亮灶
红队it44 分钟前
【Spark+Hadoop】基于spark+hadoop游戏评论数据分析可视化大屏(完整系统源码+数据库+开发笔记+详细部署教程+虚拟机分布式启动教程)✅
大数据·hadoop·分布式·算法·游戏·数据分析·spark
程序员-King.44 分钟前
day125—二分查找—寻找峰值(LeetCode-162)
算法·leetcode·职场和发展