mirror of
https://github.com/youngyangyang04/leetcode-master.git
synced 2025-07-09 19:44:45 +08:00
添加0494.目标和 Go版本
This commit is contained in:
@ -276,7 +276,35 @@ class Solution:
|
|||||||
```
|
```
|
||||||
|
|
||||||
Go:
|
Go:
|
||||||
|
```go
|
||||||
|
func findTargetSumWays(nums []int, target int) int {
|
||||||
|
sum := 0
|
||||||
|
for _, v := range nums {
|
||||||
|
sum += v
|
||||||
|
}
|
||||||
|
if target > sum {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
if (sum+target)%2 == 1 {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
// 计算背包大小
|
||||||
|
bag := (sum + target) / 2
|
||||||
|
// 定义dp数组
|
||||||
|
dp := make([]int, bag+1)
|
||||||
|
// 初始化
|
||||||
|
dp[0] = 1
|
||||||
|
// 遍历顺序
|
||||||
|
for i := 0; i < len(nums); i++ {
|
||||||
|
for j := bag; j >= nums[i]; j-- {
|
||||||
|
//推导公式
|
||||||
|
dp[j] += dp[j-nums[i]]
|
||||||
|
//fmt.Println(dp)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return dp[bag]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user