# 823. Binary Trees With Factors

#### Medium

***

Given an array of unique integers, `arr`, where each integer `arr[i]` is strictly greater than `1`.

We make a binary tree using these integers, and each number may be used for any number of times. Each non-leaf node's value should be equal to the product of the values of its children.

Return *the number of binary trees we can make*. The answer may be too large so return the answer **modulo** `109 + 7`.

&#x20;

**Example 1:**

<pre><code>Input: arr = [2,4]
<strong>Output:
</strong> 3
<strong>Explanation:
</strong> We can make these trees: [2], [4], [4, 2, 2]
</code></pre>

**Example 2:**

<pre><code>Input: arr = [2,4,5,10]
<strong>Output:
</strong> 7
<strong>Explanation:
</strong> We can make these trees: [2], [4], [5], [10], [4, 2, 2], [10, 2, 5], [10, 5, 2].
</code></pre>

&#x20;

**Constraints:**

* `1 <= arr.length <= 1000`
* `2 <= arr[i] <= 109`
* All the values of `arr` are **unique**.

```python
class Solution:
    def numFactoredBinaryTrees(self, arr):
        #.
        s_arr, N = set(arr), 10**9 + 7
        
        @lru_cache(None)
        def dp(num):
            ans = 1
            for cand in s_arr:
                if num % cand == 0 and num//cand in s_arr:
                    ans += dp(cand)*dp(num//cand)
            return ans
        
        return sum(dp(num) for num in s_arr) % N
```
