Given an integer n, return an array ans of length n + 1 such that for each i (0 <= i <= n), ans[i] is the number of 1's* in the binary representation of* i.
Example 1:
Input: n = 2
Output: [0,1,1]
Explanation:
0 --> 0
1 --> 1
2 --> 10
Example 2:
Input: n = 5
Output: [0,1,1,2,1,2]
Explanation:
0 --> 0
1 --> 1
2 --> 10
3 --> 11
4 --> 100
5 --> 101
Constraints:
0 <= n <= 105Thinking:
Index : 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
num : 0 1 1 2 1 2 2 3 1 2 2 3 2 3 3 4
Do you find the pattern?
Obviously, this is overlap sub problem, and we can come up the DP solution. For now, we need find the function to implement DP.
dp[0] = 0;
dp[1] = dp[0] + 1;