Target Sum
Problem
https://leetcode.com/problems/target-sum/
You are given an integer array nums and an integer target.
You want to build an expression out of nums by adding one of the
symbols '+' and '-' before each integer in nums and then
concatenate all the integers.
For example, if
nums = [2, 1], you can add a'+'before2and a'-'before1and concatenate them to build the expression"+2-1".
Return the number of different expressions that you can build, which
evaluates to target.
Example 1:
Input: nums = [1,1,1,1,1], target = 3
Output: 5
Explanation: There are 5 ways to assign symbols to make the sum of nums be target 3.
-1 + 1 + 1 + 1 + 1 = 3
+1 - 1 + 1 + 1 + 1 = 3
+1 + 1 - 1 + 1 + 1 = 3
+1 + 1 + 1 - 1 + 1 = 3
+1 + 1 + 1 + 1 - 1 = 3
Example 2:
Input: nums = [1], target = 1
Output: 1
Constraints:
1 <= nums.length <= 200 <= nums[i] <= 10000 <= sum(nums[i]) <= 1000-1000 <= target <= 1000
Pattern
Array, Dynamic Programming, Backtracking
Approaches
Code
def findTargetSumWays(nums: list[int], target: int) -> int:
memo = {}
def target_sum_ways(i, t):
if (i, t) in memo:
return memo[(i, t)]
if i == len(nums):
memo[(i, t)] = 1 if t == 0 else 0
return 1 if t == 0 else 0
neg_ways = target_sum_ways(i + 1, t - nums[i])
pos_ways = target_sum_ways(i + 1, t + nums[i])
memo[(i + 1, t - nums[i])] = neg_ways
memo[(i + 1, t + nums[i])] = pos_ways
return neg_ways + pos_ways
return target_sum_ways(0, target)
Test
>>> from target_sum__memoization import findTargetSumWays
>>> findTargetSumWays([1, 1, 1, 1, 1], 3)
5
>>> findTargetSumWays([1], 1)
1
- target_sum__memoization.findTargetSumWays(nums: list[int], target: int) int