Problem

Numbers can be regarded as product of its factors. For example,

8 = 2 x 2 x 2;
  = 2 x 4.

Write a function that takes an integer n and return all possible combinations of its factors.

Note:

  1. You may assume that n is always positive.
  2. Factors should be greater than 1 and less than n.

Examples

Example 1:

Input: n = 1
Output:
 []

Example 2:

Input n = 37
Output:
[]

Example 3:

Input:n = 12
Output:
[
  [2, 6],
  [2, 2, 3],
  [3, 4]
]

Example 4:

Input n = 32
Output:
[
  [2, 16],
  [2, 2, 8],
  [2, 2, 2, 4],
  [2, 2, 2, 2, 2],
  [2, 4, 4],
  [4, 8]
]

Solution

Method 1 - Backtracking

We can iterate from i = 2 to n. If the current number i is divisible by n, it means that i is a factor of n. Store it in a currFactors list, and then recursively call n/i.

At next recursion, do not traverse from 2. It traverses from i to n/i, and the condition for stopping is when n is equal to 1, if there is a factor in onePath at this time, store this combination in the result.

Code

Java
class Solution {
    private List<Integer> currFactors = new ArrayList<>();
    private List<List<Integer>> ans = new ArrayList<>();

    public List<List<Integer>> getFactors(int n) {
        dfs(n, 2);
        return ans;
    }

    private void dfs(int n, int i) {
        if (!currFactors.isEmpty()) {
	        List<Integer> subAns = new ArrayList<>(currentFactors);
	        subAns.add(n);
            ans.add(subAns);
        }
        for (int j = i; j <= n / j; j++) {
            if (n % j == 0) {
                currFactors.add(j);
                dfs(n / j, j);
                currFactors.remove(currFactors.size() - 1); // backtrack
            }
        }
    }
}

Dry Run

Take eg. 3, n = 12.

We start DFS with n = 12, i = 2

DFS Level 0
n = 12, i = 2
currFactors is empty, so nothing to do
j = 2, L = n / j = 6; j <= L and n %j == 0 is true
currFactors = [2]
dfs(6, 2)

This opens up a new recursion call

DFS Level 1
n = 6, i = 2
currFactors = [2] is not empty, so ans += (currFactors + n) =[[2, 6]]


j = 2, , L = n / j = 3; j <= L and n % 2 == 0 is true
currFactors = [2, 2]
dfs(3, 2)

Now, we got to next recursion call:

DFS Level 2
n = 3, i = 2
currFactors = [2, 2] is not empty, so ans += (currFactors + n)
currFactors + n = [2, 2, 3]
ans =[[ 2, 6 ], [2, 2, 3]]

j = 2, , L = n / j = 1; j <= L is false, hence we won't enter the loop

We backtrack to dfs level 1

and so on.

DFS Level 1
n = 6, i = 2

Now, we pop out last added 2 currFactors
currFactors = [2]
j = 3, L = n / j = 2. j <= L is false, hence our loop is done. We got to dfs level 0
DFS Level 0
n = 12, i = 2

Now, we pop out last added 2 currFactors
currFactors = []
j = 3, L = n / j = 4; j <= L and n %j == 0 is true
currFactors = [3]
dfs(4, 3)
New DFS Level 1
n = 4, i = 3
currFactors = [3] is not empty, so ans += (currFactors + n)
currFactors + n = [3, 4]
ans =[[ 2, 6 ], [2, 2, 3], [3, 4]]

j = 3,  L = n / j = 1. j <= L is false, hence our loop is done. We got to dfs level 0
DFS Level 0
n = 12, i = 2

Now, we pop out last added 3 currFactors
currFactors = []
j = 4, L = n / j = 3; j <= L is false, hence we are out of loop, and our DFS is over.
Ans

Hence, eventually, [[ 2, 6 ], [2, 2, 3], [3, 4]] is answer.