前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Dynamic Programming - 279. Perfect Squares

Dynamic Programming - 279. Perfect Squares

作者头像
ppxai
发布2020-09-23 17:27:46
3820
发布2020-09-23 17:27:46
举报
文章被收录于专栏:皮皮星球皮皮星球

279. Perfect Squares

Given a positive integer n, find the least number of perfect square numbers (for example, 1, 4, 9, 16, ...) which sum to n.

Example 1:

Input: n = 12 Output: 3 Explanation: 12 = 4 + 4 + 4.

Example 2:

Input: n = 13 Output: 2 Explanation: 13 = 4 + 9.

思路:

题目意思是求能用最少的完全平方表示一个数,有一个四平方和定理,可以在O(n)内解决问题,但是这里选择用动态规划来做,子问题就是一个数是由另一个数加上一个平方数,也就是比如A = B + x^2, 而B由是子问题求解,这样的话,能表示A的最少组合就是B最少组合加一,所以动态转移方程就是:dp[i] = min{dp[ i - j*j] + 1}, (j*j <= i),初始条件是dp[0] = 0, 因为0不能由状态方程求出。求解顺序很明显是从小到大。

代码:

go:

代码语言:javascript
复制
func numSquares(n int) int {
    dp := make([]int, n+1)
    for i := 0; i < n+1; i++ {
        dp[i] = math.MaxInt32
    }
    
    dp[0] = 0;
    for i := 1; i <= n; i++ {
        // dp[n] = min(dp[n-x^2] + 1) for all x
        for j := 1; j * j <= i; j++ {
            dp[i] = min(dp[i], dp[i- j*j] + 1)
        }
    }

    return dp[n]
}

func min(i, j int) int {
    if i < j {
        return i
    }
    return j
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年08月01日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档