Day41| Leetcode 343. 整数拆分 Leetcode 96. 不同的二叉搜索树

Leetcode 343. 整数拆分

题目链接 343 整数拆分

dp[i]的含义对i进行拆分,得到最大的整数

固定一个j用for循环来遍历,剩下的按照i-j来算,拆分成两个数是j*(i-j),拆分为三个及其以上需要j*dp[i-j],下面上代码:

class Solution {
public:int integerBreak(int n) {vector<int> dp(n + 1);//vector数组定义dp[2] = 1;for(int i=3;i<=n;i++){for(int j=1;j<i;j++){dp[i] = max(dp[i],max(dp[i-j]*j,(i-j)*j));}} return dp[n];}
};

Leetcode 96. 不同的二叉搜索树

题目链接 96 不同的二叉搜索树

本题目有点找规律的意思。

dp[i]是由dp[0],dp[1].dp[2]来推出来的

dp[3],就是 元素1为头结点搜索树的数量 + 元素2为头结点搜索树的数量 + 元素3为头结点搜索树的数量

元素1为头结点搜索树的数量 = 右子树有2个元素的搜索树数量 * 左子树有0个元素的搜索树数量

元素2为头结点搜索树的数量 = 右子树有1个元素的搜索树数量 * 左子树有1个元素的搜索树数量

元素3为头结点搜索树的数量 = 右子树有0个元素的搜索树数量 * 左子树有2个元素的搜索树数量

有2个元素的搜索树数量就是dp[2]。

有1个元素的搜索树数量就是dp[1]。

有0个元素的搜索树数量就是dp[0]。

所以dp[3] = dp[2] * dp[0] + dp[1] * dp[1] + dp[0] * dp[2]

在上面的分析中,其实已经看出其递推关系, dp[i] += dp[以j为头结点左子树节点数量] * dp[以j为头结点右子树节点数量]

j相当于是头结点的元素,从1遍历到i为止。

所以递推公式:dp[i] += dp[j - 1] * dp[i - j](dp[1],dp[2]在递推公式中可以推断出,所以不用初始化); ,j-1 为j为头结点左子树节点数量(左边的节点一定小于j),i-j 为以j为头结点右子树节点数量(右边的节点一定大于j)

零个节点也是二叉搜索树。

下面上代码:

class Solution {
public:int numTrees(int n) {vector<int>dp(n+1);dp[0] = 1;for(int i=1;i<=n;i++){for(int j=1;j<=i;j++){dp[i]+= dp[j-1]*dp[i-j];}}return dp[n];}
};

end

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/199361.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Hadoop学习笔记(HDP)-Part.12 安装HDFS

目录 Part.01 关于HDP Part.02 核心组件原理 Part.03 资源规划 Part.04 基础环境配置 Part.05 Yum源配置 Part.06 安装OracleJDK Part.07 安装MySQL Part.08 部署Ambari集群 Part.09 安装OpenLDAP Part.10 创建集群 Part.11 安装Kerberos Part.12 安装HDFS Part.13 安装Ranger …

基本类型优先于包装类型

基本类型和包装类型之间有三个主要区别&#xff1a; 1、基本类型只有值&#xff0c;而两个包装类型可以具有相同的值和不同的同一性&#xff08;值相同&#xff0c;但是false&#xff09; 2、基本类型只有功能完备的值&#xff0c;而每个包装类型除了它对应基本类型的所有功能…

RAR文件的密码保护如何设置和取消?

RAR文件是压缩包一种常用的压缩文件格式&#xff0c;对于这种文件&#xff0c;我们如何设置和取消密码保护呢&#xff1f; 首先我们要下载适用于RAR文件的WinRAR解压缩软件&#xff0c;然后在压缩文件的时候&#xff0c;就可以同步设置密码&#xff0c;选中需要压缩的文件&…

在外包公司干测试半年,提升的只有我的年龄···

有一说一&#xff0c;外包没有给很高的薪资&#xff0c;是真不能干呀&#xff01; 先说一下自己的情况&#xff0c;本科生&#xff0c;年初通过校招进入深圳某软件公司&#xff0c;干了接近半年的功能测试&#xff0c;直到最近遇到了瓶颈&#xff0c;感觉自己不能够在这样下去了…

qnx hypervisor load qvm

//解析dts 获取node qcom_gvms 参考博客:https://blog.csdn.net/liaochaoyun/article/details/127427719 startup-qvmhost.sh startup.sh1419 waitfor /dev/lcm_demo/display0 1420 if [ $RECOVERY_MODE -eq 0 ]; then 1421 log_launch $VMM_SERVICE_BINARY #启动 vmm_ser…

Linux C++ 贪吃蛇游戏 -- 方向键控制蛇移动

1. 代码 #include <iostream> #include <ncurses.h> #include <vector> #include <cstdlib> #include <ctime> #include <thread>using namespace std;// 定义方向 enum class Direction { UP, DOWN, LEFT, RIGHT };class SnakeGame { pu…

分享5款小伙伴们推荐的好用软件

​ 转眼间2023年已经只剩下一个月了&#xff0c;最近陆陆续续收到好多小伙伴的咨询&#xff0c;这边也是抓紧整理出几个好用的软件&#xff0c;希望可以帮到大家。 1.文件格式转换——Convertio ​ Convertio是一款在线文件格式转换软件&#xff0c;可以让用户在不同的文件格…

【开题报告】基于SSM的校园爱心帮扶系统的设计与实现

1.选题背景 校园爱心帮扶系统是基于SSM&#xff08;SpringSpringMVCMyBatis&#xff09;框架的设计与实现&#xff0c;旨在促进校园内的爱心互助和帮扶活动。以下是一些可能的选题背景&#xff1a; &#xff08;1&#xff09;社会责任感的提升&#xff1a;随着社会发展&#…

Python sorted函数及用法以及如何用json模块存储数据

Python sorted函数及用法 sorted() 函数与 reversed() 函数类似&#xff0c;该函数接收一个可迭代对象作为参数&#xff0c;返回一个对元素排序的列表。 在交互式解释器中测试该函数&#xff0c;可以看到如下运行过程&#xff1a; >>> a [20, 30, -1.2, 3.5, 90, 3.…

MongoInvalidArgumentError: Argument “docs“ must be an array of documents

这个错误通常表示在 MongoDB 操作中&#xff0c;你提供的参数不符合预期。错误信息指出了 docs 参数必须是一个文档&#xff08;document&#xff09;数组&#xff0c;但实际上提供的参数类型可能与预期不符。 假设你在使用 MongoDB 的一个函数或方法时出现了这个错误。以下是…

Linux系统---图书管理中的同步问题

顾得泉&#xff1a;个人主页 个人专栏&#xff1a;《Linux操作系统》 《C/C》 《LeedCode刷题》 键盘敲烂&#xff0c;年薪百万&#xff01; 一、问题描述 &#xff08;1&#xff09;图书馆阅览室最多能够容纳N&#xff08;N5&#xff09;名学生&#xff0c;若有更多学生想…

FFmpeg的C++封装:FFmpegWrapper

什么是FFmpeg&#xff1f; FFmpeg 是一套完整的录制、转换、流化音视频的解决方案&#xff0c;也是一个在LGPL协议 下的开源项目。它包含了业界领先的音视频编解码库。FFmpeg是在Linux操作系统下开发的&#xff0c;但它也能在其他操作系统下编译&#xff0c;包括Windows。 整…

java常用字符串工具方法封装

Java常用的字符串工具方法有很多&#xff0c;以下是一些常见的封装&#xff1a; 判断字符串是否为空或null public static boolean isNullOrEmpty(String str) {return str null || str.trim().isEmpty(); }判断字符串是否为数字 public static boolean isNumeric(String s…

跨境代采怎么实现(代采网站)

中国代购作为一种新型的业务形式&#xff0c;此类服务能够帮助消费者购买来自全球的商品&#xff0c;同时也为商家提供了在线销售机会。代购行业的兴起&#xff0c;有助于打破传统的地域和跨境限制&#xff0c;促进了国际贸易和经济发展。 一、中国代购的定义和特点 代购可以被…

冬季吃得过饱?羊大师教你几招消食的小妙招!

冬季吃得过饱&#xff1f;羊大师教你几招消食的小妙招&#xff01; 冬季是人们容易吃得过饱的季节&#xff0c;美食诱惑频出&#xff0c;很容易导致胃口过大&#xff0c;饭量过多&#xff0c;造成消化不良甚至影响身体健康。所以&#xff0c;如何消食&#xff0c;让胃得到缓解…

如何拆解Unity 2022.3版本的AssetBundle

1&#xff09;如何拆解Unity 2022.3版本的AssetBundle 2&#xff09;Unity 2022 LTS版本的稳定性 3&#xff09;关于AssetBundle禁用TypeTree之后的一些可序列化的问题 这是第363篇UWA技术知识分享的推送&#xff0c;精选了UWA社区的热门话题&#xff0c;涵盖了UWA问答、社区帖…

long转int类型转换问题

在业务代码中排序时需要根据日期排序&#xff0c;写了如下代码 sorted((o1, o2) -> {String str1 null;String str2 null;try {Field field getField(fieldMap, configBO.getCodeName());str1 String.valueOf(field.get(o1));str2 String.valueOf(field.get(o2));} ca…

【Qt开发流程】之对象模型1:信号和槽

Qt对象模型 标准c对象模型为对象范型提供了非常有效的运行时支持。但是它的静态特性在某些问题领域是不灵活的。图形用户界面编程是一个既需要运行时效率又需要高度灵活性的领域。Qt通过结合c的速度和Qt对象模型的灵活性提供了这一点。 Qt将这些特性添加到c中: 一个非常强大的…

基于Go语言实现简易Web应用

目录 前言Go语言特点写在使用Go语言实现Web应用前面创建Web服务器声明一个结构体操作加入中间件的使用使用静态文件服务器最后 前言 在编程语言中&#xff0c;近几年问世的几个新语言都是非常不错的&#xff0c;比如Go、Python、 Rust等等。其中&#xff0c;Go语言(Golang)作…

CookieSession Redis 到JWT会话管理历史

单应用时期&#xff0c;通常使用 Cookies 和 Session 进行会话管理。 用户登录后&#xff0c;服务器创建一个唯一的会话标识符&#xff08;Session ID&#xff09;&#xff0c;将其存储在浏览器的 Cookies 中&#xff0c;并在服务端维护一个关联该标识符的会话对象。 这种方…