代码随想录第三十五天(一刷C语言)|整数拆分不同的二叉搜索树

本文主要是介绍代码随想录第三十五天(一刷C语言)|整数拆分不同的二叉搜索树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

创作目的:为了方便自己后续复习重点,以及养成写博客的习惯。

一、整数拆分

思路:参考carl文档。

1、确定dp数组以及下标的含义:分拆数字i,可以得到的最大乘积为dp[i]。

2、确定递推公式:从1遍历j,dp[i]可以由j * (i - j) 直接相乘。也可以由j * dp[i - j](相当于是拆分(i - j))得到。dp[i] = max(dp[i], max((i - j) * j, dp[i - j] * j))。

3、dp数组的初始化:初始化dp[2] = 1,从dp[i]的定义来说,拆分数字2,得到的最大乘积是1。

拆分0与1是无意义的。

4、确定遍历的方向:由递推公式知遍历方向为从左到右。

5、举例n为某个数的时候,推到dp数组。

ledcode题目:https://leetcode.cn/problems/integer-break/

AC代码:

//初始化DP数组
int *initDP(int num) {int* dp = (int*)malloc(sizeof(int) * (num + 1));int i;for(i = 0; i < num + 1; ++i) {dp[i] = 0;}return dp;
}//取三数最大值
int max(int num1, int num2, int num3) {int tempMax = num1 > num2 ? num1 : num2;return tempMax > num3 ? tempMax : num3;
}int integerBreak(int n){int *dp = initDP(n);//初始化dp[2]为1dp[2] = 1;int i;for(i = 3; i <= n; ++i) {int j;for(j = 1; j < i - 1; ++j) {//取得上次循环:dp[i],原数相乘,或j*dp[]i-j] 三数中的最大值dp[i] = max(dp[i], j * (i - j), j * dp[i - j]);}}return dp[n];
}

二、不同的二叉搜索树

思路:参考carl文档。

1、确定dp数组及其下标的含义:1到i为节点组成的二叉搜索树的个数为dp[i]。

2、确定递推公式:dp[i] += dp[j - 1] * dp[i - j] ,j-1 为j为头结点左子树节点数量,i-j 为以j为头结点右子树节点数量。

3、dp数组的初始化:空节点也是一棵二叉树,也是一棵二叉搜索树。初始化dp[0] = 1。并且防止左右子树相乘出现0值的情况。

4、确定遍历方向:由递推公式知,节点数为i的状态依靠于 i之前节点数的状态。故遍历i里面每一个数作为头结点的状态,用j来遍历。

5、举例n为某个数的时候dp数组的状态。

lecode题目:https://leetcode.cn/problems/unique-binary-search-trees/description/

AC代码:

//开辟dp数组
int *initDP(int n) {int *dp = (int *)malloc(sizeof(int) * (n + 1));int i;for(i = 0; i <= n; ++i)dp[i] = 0;return dp;
}int numTrees(int n){//开辟dp数组int *dp = initDP(n);//将dp[0]设为1dp[0] = 1;int i, j;for(i = 1; i <= n; ++i) {for(j = 1; j <= i; ++j) {//递推公式:dp[i] = dp[i] + 根为j时左子树种类个数 * 根为j时右子树种类个数dp[i] += dp[j - 1] * dp[i - j];}}return dp[n];
}

这篇关于代码随想录第三十五天(一刷C语言)|整数拆分不同的二叉搜索树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/510986

相关文章

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill