forked from LeetCode-in-Python/LeetCode-in-Python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSolution.py
30 lines (24 loc) · 1.01 KB
/
Solution.py
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
# #Medium #Array #Dynamic_Programming #Backtracking #Big_O_Time_O(n*(sum+s))_Space_O(n*(sum+s))
# #2024_06_07_Time_105_ms_(86.96%)_Space_16.7_MB_(80.93%)
class Solution:
def findTargetSumWays(self, nums: List[int], target: int) -> int:
total_sum = sum(nums)
s = abs(target)
# Invalid s, just return 0
if s > total_sum or (total_sum + s) % 2 != 0:
return 0
target = (total_sum + s) // 2
dp = [[0] * (len(nums) + 1) for _ in range(target + 1)]
dp[0][0] = 1
# empty knapsack must be processed specially
for i in range(len(nums)):
if nums[i] == 0:
dp[0][i + 1] = dp[0][i] * 2
else:
dp[0][i + 1] = dp[0][i]
for i in range(1, target + 1):
for j in range(len(nums)):
dp[i][j + 1] += dp[i][j]
if nums[j] <= i:
dp[i][j + 1] += dp[i - nums[j]][j]
return dp[target][len(nums)]