Tony's Log

Algorithms, Distributed System, Machine Learning

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

An interesting DFS with a lot of details to take care of.

class Solution {
    vector<vector<int>> ret;
    void go(int n, vector<int> sofar, int minF)
    {
        int start = n % 2 ? 3 : 2;
        for (int f = start; f <= n / 2; f += 1)
        {
            if (f >= minF && n % f == 0 && (n / f) >= f)
            {
                vector<int> r = sofar;
                r.push_back(f);
                r.push_back(n/f);
                ret.push_back(r);
                
                r.pop_back();
                go(n / f, r, f);
            }
        }
    }
public:
    vector<vector<int>> getFactors(int n) {
        go(n, vector<int>(), 2);
        return ret;
    }
};
posted on 2015-08-23 12:43  Tonix  阅读(260)  评论(0)    收藏  举报