算法训练营day35(补),动态规划3

func max(a, b int) int {

if a > b {

return a

}

return b

}

//343. 整数拆分

//拆分的数尽量相等才能保证最大

func integerBreak(n int) int {

dp := make([]int, n+1)

// 初始值,0,1没有意义,为零,2可以拆为1*1=1

dp[2] = 1

for i := 3; i <= n; i++ {

for j := 1; j <= i/2; j++ {

dp[i] = max(max(j*(i-j), j*dp[i-j]), dp[i])

}

}

return dp[n]

}

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

func numTrees(n int) int {

if n == 0 {

return 1

}

dp := make([]int, n+1)

dp[0] = 1

for i := 1; i <= n; i++ {

for j := 1; j <= i; j++ {

dp[i] += dp[j-1] * dp[i-j]

}

}

return dp[n]

}

相关推荐
Amor风信子6 分钟前
【力扣】2376. 统计特殊整数
算法·leetcode·职场和发展
极客小张7 分钟前
基于正点原子Linux开发板的智能监控与家电控制系统设计:深度解析Video4Linux和TCP/IP技术栈
linux·运维·c++·物联网·网络协议·tcp/ip·算法
JustCouvrir1 小时前
代码随想录算法训练营Day5
算法
周哈里窗的编程2 小时前
CSP-CCF★201912-2回收站选址★
c++·算法·图论
SpongeG3 小时前
数据结构第三周做题总结_链表
数据结构·算法·链表
everyStudy3 小时前
前端五种排序
前端·算法·排序算法
little redcap5 小时前
第十九次CCF计算机软件能力认证-乔乔和牛牛逛超市
数据结构·c++·算法
muyierfly6 小时前
34.贪心算法1
算法·贪心算法
luthane8 小时前
python 实现average mean平均数算法
开发语言·python·算法
静心问道8 小时前
WGAN算法
深度学习·算法·机器学习