279. Perfect Squares

class Solution {
public:
    int numSquares(int n) {
        vector<int> res(n + 1, 5);
        res[0] = 0;
        for (int i = 1; i <= n; i++)
            for (int j = 1; j * j <= i; j++)
                res[i] = min(res[i - j * j] + 1, res[i]);
        return res[n];

//bfs just died when submitting anwser
/*        vector<int> res(n + 1, -1);
        vector<int> squareNumber;
        queue<int> BFS;
        for (int i = 1; i * i <= n; i++) {
            squareNumber.push_back(i * i);
            BFS.push(i * i);
            res[i * i] = 1;
        }

        if (squareNumber.empty() || squareNumber.back() == n) return 1;
        while (!squareNumber.empty()) {
            int curr = BFS.front() ;
            for (int i = 0; i < squareNumber.size(), curr + squareNumber[i] <= n; i++) {
                if (curr + squareNumber[i] == n) return res[curr] + 1;
                if (res[curr + squareNumber[i]] == -1) {
                    BFS.push(curr + squareNumber[i]);
                    res[curr + squareNumber[i]] = res[curr] + 1;
                    cout<<curr + squareNumber[i]<<' '<<res[curr + squareNumber[i]]<<endl;
                }
            }
            BFS.pop();
        }

        return res[n];*/
    }
};

results matching ""

    No results matching ""