2021-01-23
程序员文章站
2024-03-23 10:31:16
...
刷题日记1:力扣343.integer break
题目:将一个数字拆分成多个整数(最少两个),使它们的乘积最大
思路
1、DP
状态转移方程
dp[i] = max(dp[i],j*(i-j),j*dp[i-j])
GO版本
func integerBreak(n int) int {
return method_dp(n)
}
/*
原因:n <=3 时 最大乘积dp[n] < n,因此需要使用max(n, dp[n])
dp[i] = getMax(dp[i], i > j ==> j * max(i-j, dp[i-j]))
*/
func method_dp(n int) int {
dp := make([]int, n+1)
dp[1] = 1
dp[2] = 1
for i := 3; i <=n; i++ {
for j := 1; j < i; j++ {
dp[i] = getMax(dp[i], j * getMax(i-j, dp[i-j]))
}
}
// fmt.Println(dp)
return dp[n]
}
func getMax(a, b int) int {
if a > b {
return a
}
return b
}
知识点总结:
1、make 用法
make只能为slice, map, channel分配内存,并返回一个初始化的值。make有以下三种不同的用法:
1. make(map[string]string)
2. make([]int, 2)
3. make([]int, 2, 4)
1. 第一种用法,即缺少长度的参数,只传类型,这种用法只能用在类型为map或chan的场景,例如make([]int)是会报错的。这样返回的空间长度都是默认为0的。
2. 第二种用法,指定了长度,例如make([]int, 2)返回的是一个长度为2的slice
3. 第三种用法,第二参数指定的是切片的长度,第三个参数是用来指定预留的空间长度,例如a := make([]int, 2, 4), 这里值得注意的是返回的切片a的总长度是4,预留的意思并不是另外多出来4的长度,其实是包含了前面2个已经切片的个数的。所以举个例子当你这样用的时候 a := make([]int, 4, 2),就会报语法错误。
剑指offer14-1 割绳子
func cuttingRope(n int) int {
dp := make(map[int]int)
dp[1] = 1 // 首项
for i := 2; i < n+1; i++ {
j, k := 1, i-1
res := 0
for j <= k {
res = max(res, max(j, dp[j])*max(k, dp[k])) // 递推公式
j++
k--
}
dp[i] = res
}
return dp[n]
}
func max(i int, j int) int {
if i > j {
return i
}
return j
}
上一篇: bean:define用法
下一篇: go语言刷题:20. 有效的括号
推荐阅读