-
Notifications
You must be signed in to change notification settings - Fork 2.4k
/
Copy path0494-target-sum.cpp
34 lines (28 loc) · 1015 Bytes
/
0494-target-sum.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
/*
Given int array & a target, want to build expressions w/ '+' & '-'
Return number of different expressions that evaluates to target
Recursion w/ memoization, cache on (index, total), which stores # ways
If total ever reaches the target, return 1 (this is a way), else 0
Time: O(n x target)
Space: O(n x target)
*/
class Solution {
public:
int findTargetSumWays(vector<int>& nums, int target) {
return backtrack(nums, target, 0, 0);
}
private:
// {(index, total) -> # of ways}
map<pair<int, int>, int> dp;
int backtrack(vector<int>& nums, int target, int i, int total) {
if (i == nums.size()) {
return total == target ? 1 : 0;
}
if (dp.find({i, total}) != dp.end()) {
return dp[{i, total}];
}
dp[{i, total}] = backtrack(nums, target, i + 1, total + nums[i])
+ backtrack(nums, target, i + 1, total - nums[i]);
return dp[{i, total}];
}
};