279. 完全平方数

问题

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量 。

完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,1、4、9 和 16 都是完全平方数,而 3 和 11 不是。

示例 1:
输入:n = 12
输出:3
解释:12 = 4 + 4 + 4

分析

dfs比较简单好写。递推还是得再学习一下怎么想。

代码

class Solution {
public:
    vector<int> nums;
    int n_n = 0;
    int mem[101][10010];
    const int INF = 1e9;
    int dfs(int x, int left) {
        if (x >= n_n) {return INF;}
        if (left == 0) {return 0;}
        if (mem[x][left]!=-1) {return mem[x][left];}
        int s = 0;
        if (left < nums[x]) {
            s = dfs(x+1, left);
        } else {
            s = min(dfs(x+1, left), dfs(x, left-nums[x])+1);
        }
        mem[x][left] = s;
        return s;
    }
    int numSquares(int n) {
        memset(mem, -1, sizeof mem);
        for (int i = 1; i*i <= n; i++) {
            nums.push_back(i*i);
        }
        n_n = nums.size();
        int res = dfs(0, n);
        return res;
    }
};
posted @ 2025-06-20 00:59  saulstavo  阅读(14)  评论(0)    收藏  举报