码迷,mamicode.com
首页 > 其他好文 > 详细

完全背包解一个数的完全平方

时间:2019-10-06 14:52:41      阅读:72      评论:0      收藏:0      [点我收藏+]

标签:square   一个   math   lse   class   new   n+1   for   col   

class Solution {
    private int w[];
    private int dp[];
    
    public int numSquares(int n) {
        w=new int[(int) (Math.sqrt(n)+1)];
        dp=new int[n+1];
        for(int i=1;i<=Math.sqrt(n);++i) {
            w[i]=i*i;
        }
        for(int i=1;i<w.length;++i) {
            for(int j=w[i];j<=n;++j) {
                if(j==w[i]) {
                    dp[j]=1;
                }else {
                    if(dp[j-w[i]]!=0) {
                        if(dp[j]==0) {
                            dp[j]=dp[j-w[i]]+1;
                        }else {
                            dp[j]=Math.min(dp[j], dp[j-w[i]]+1);
                        }
                    }
                }
            }
        }
        return dp[n];
        
    }
}

 

完全背包解一个数的完全平方

标签:square   一个   math   lse   class   new   n+1   for   col   

原文地址:https://www.cnblogs.com/z2529827226/p/11627216.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!