欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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
}

 

 

 

相关标签: 刷题 go

推荐阅读