Return the number of ways n can be expressed as the sum of the xth power of unique positive integers, in other words, the number of sets of unique integers [n1, n2, ..., nk] where n = n1x + n2x + ... + nkx.
Since the result can be very large, return it modulo 109 + 7.
For example, if n = 160 and x = 3, one way to express n is n = 23 + 33 + 53.
Example 1:
Input: n = 10, x = 2
Output: 1
Explanation: We can express n as the following: n = 32 + 12 = 10.
It can be shown that it is the only way to express 10 as the sum of the 2nd power of unique integers.
Example 2:
Input: n = 4, x = 1
Output: 2
Explanation: We can express n in the following ways:
- n = 41 = 4.
- n = 31 + 11 = 4.
Constraints:
1 <= n <= 300
1 <= x <= 5
Solutions
Solution 1: Dynamic Programming
We define \(f[i][j]\) as the number of ways to select some numbers from the first \(i\) positive integers such that the sum of their \(x\)-th powers equals \(j\). Initially, \(f[0][0] = 1\), and all others are \(0\). The answer is \(f[n][n]\).
For each positive integer \(i\), we can choose to either include it or not:
Not include it: the number of ways is \(f[i-1][j]\);
Include it: the number of ways is \(f[i-1][j-i^x]\) (provided that \(j \geq i^x\)).