首页 > 其他 > 详细

[?]*Factor Combinations

时间:2015-12-30 06:58:50      阅读:148      评论:0      收藏:0      [点我收藏+]

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. Each combination‘s factors must be sorted ascending, for example: The factors of 2 and 6 is [2, 6], not [6, 2].
  2. You may assume that n is always positive.
  3. Factors should be greater than 1 and less than n.

 

Examples: 
input: 1
output: 

[]
input: 37
output: 
[]
input: 12
output:
[
  [2, 6],
  [2, 2, 3],
  [3, 4]
]
input: 32
output:
[
  [2, 16],
  [2, 2, 8],
  [2, 2, 2, 4],
  [2, 2, 2, 2, 2],
  [2, 4, 4],
  [4, 8]
]

recursion的解法:
public class Solution {
 public List<List<Integer>> getFactors(int n) {
    List<List<Integer>> result = new ArrayList<List<Integer>>();
    helper(result, new ArrayList<Integer>(), n, 2);
    return result;
}

public void helper(List<List<Integer>> result, List<Integer> item, int n, int start){
    if (n <= 1) {
        if (item.size() > 1) {
            result.add(new ArrayList<Integer>(item));
        System.out.println("add item to result");
        }
        return;
    }

    for (int i = start; i <= n; ++i) {
        if (n % i == 0) {
            item.add(i);
            System.out.println("item");
            System.out.println(item);
            helper(result, item, n/i, i);
            item.remove(item.size()-1);
            System.out.println("removed item");
            System.out.println(item);
        }
    }
}
}

运行结果:

test case n=8

item
[2]
item
[2, 2]
item
[2, 2, 2]
add to result
removed item
[2, 2]
removed item
[2]
item
[2, 4]
add to result
removed item
[2]
removed item
[]
item
[4]
removed item
[]
item
[8]
removed item
[]

 

结果: 

Your answer

[[2,2,2],[2,4]]


Expected answer

[[2,4],[2,2,2]]

 

reference:https://leetcode.com/discuss/51250/my-recursive-dfs-java-solution

 

[?]*Factor Combinations

原文:http://www.cnblogs.com/hygeia/p/5087613.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!