leetcode 279. Perfect Squares

本题也是完全背包问题。并且本质上与第322题一模一样。要求的是装满背包最少需要多少个物品。与第322题一样,dp数组的初始化需要仔细考虑。详见leetcode 322. Coin Change

本题,给定整数n就相当于给定容量大小为n的背包。n只可能等于,1,4,9,...,这些完全平方数的和。相当于物品个数就是,物品重量是1,4,9,...,

第一版代码

外层循环遍历物品,内层循环遍历背包容量。

cpp 复制代码
class Solution {
public:
    int numSquares(int n) {
        int m = sqrt(n);
        //dp[j]表示和为j的完全平方数的最少数量
        vector<int> dp(n+1,n+1);
        //从题意可以看出,虽然0等于0的平方,但是本题完全平方数不包含0
        //dp[0]初始化为0表示,无法找到和为0的完全平方数
        dp[0] = 0;
        for(int i = 1;i <=m;i++){//外层循环对物品遍历
            for(int j = i*i;j <=n;j++){//内层循环对背包容量遍历
                dp[j] = min(dp[j],dp[j-i*i]+1);
            }
        }
        return dp[n];
    }
};

第二版代码

外层循环遍历背包容量,内层循环遍历物品。

cpp 复制代码
class Solution {
public:
    int numSquares(int n) {
        int m = sqrt(n);
        //dp[j]表示和为j的完全平方数的最少数量
        vector<int> dp(n+1,n+1);
        //从题意可以看出,虽然0等于0的平方,但是本题完全平方数不包含0
        //dp[0]初始化为0表示,无法找到和为0的完全平方数
        dp[0] = 0;
        // for(int i = 1;i <=m;i++){//外层循环对物品遍历
        //     for(int j = i*i;j <=n;j++){//内层循环对背包容量遍历
        //         dp[j] = min(dp[j],dp[j-i*i]+1);
        //     }
        // }
        for(int j = 0;j<=n;j++){//外层循环对背包容量遍历
            for(int i = 1;i<=m;i++){//内层循环对物品遍历
                if(j>=i*i)
                    dp[j] = min(dp[j],dp[j-i*i]+1);
            }
        }
        return dp[n];
    }
};
相关推荐
不知天地为何吴女士1 小时前
Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法
小坏坏的大世界1 小时前
C++ STL常用容器总结(vector, deque, list, map, set)
c++·算法
励志要当大牛的小白菜4 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970444 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵5 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
爱喝矿泉水的猛男7 小时前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展
YuTaoShao7 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
YouQian7728 小时前
Traffic Lights set的使用
算法
go54631584659 小时前
基于深度学习的食管癌右喉返神经旁淋巴结预测系统研究
图像处理·人工智能·深度学习·神经网络·算法
aramae9 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法