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];
    }
};
相关推荐
C+-C资深大佬3 分钟前
C++ 数字与字符串互转
java·c++·算法
满怀冰雪9 分钟前
第12篇-二分答案法-当答案不好求时如何反向搜索
java·算法
KaMeidebaby11 分钟前
卡梅德生物技术快报|兔单克隆抗体应用实战:禽源病原 IFA 检测全流程拆解
前端·人工智能·物联网·算法·百度
CC数学建模13 分钟前
2026年第十六届APMCM 亚太地区大学生数学建模竞赛(中文赛项)赛题A题:自来水厂水质预测与评估完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
折哥的程序人生 · 物流技术专研8 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
想吃火锅100510 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
云絮.11 小时前
数据库操作
数据库·mysql·算法·oracle
小林ixn11 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫11 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
菜鸟‍13 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展