代码随想录 Leetcode494. 目标和

题目:


代码(首刷看解析 2024年2月26日)

思路:根据题意,设两个背包,packageA存放前面是"+"的数字之和,packageB存放前面是"-"的数字之和

则sum = packageA + packageB;

target = packageA - packageB;

则根据以上算式可得packageA = (sum + target)/2;

因为sum和target根据题目都已知,则问题变成求可以放哪些数使得和 == packageA--即动态规划01背包问题

cpp 复制代码
class Solution {
public:
    int findTargetSumWays(vector<int>& nums, int target) {
        int sum = 0;
        for (int& num :nums) {
            sum += num;
        }
        if (sum < abs(target)) return 0; 
        int tmp = sum + target;
        if (tmp % 2 == 1) return 0;
        int x = tmp / 2;
        vector<int> dp(x + 1, 0);
        dp[0] = 1;
        for (int i = 0; i < nums.size(); ++i) {
            for (int j = x; j >= nums[i]; --j) {
                dp[j] += dp[j - nums[i]];
            }
        }
        return dp[x];
    }
};
相关推荐
无双@10 分钟前
高并发内存池9 —— Page Cache 回收
c++·线程·秋招·项目·高并发内存池·c++项目·内存池
卡提西亚29 分钟前
C++笔记-26-类模板
c++·笔记
沐怡旸1 小时前
【穿越Effective C++】条款19:设计class犹如设计type——用户定义类型的艺术与科学
c++·面试
一个不知名程序员www1 小时前
算法学习入门---模拟(C++)
c++·算法
夜月yeyue1 小时前
嵌入式开发中的 Git CI/CD
c++·git·单片机·嵌入式硬件·ci/cd·硬件架构
搂鱼1145141 小时前
GJOI 11.10 题解
算法
爱睡觉的咋1 小时前
openGauss × AI:打造一个能识图、能讲解、还能推荐的智慧博物馆导览师
算法
编程之路,妙趣横生1 小时前
类和对象(下)
c++
视觉AI1 小时前
一帧就能“训练”的目标跟踪算法:通俗理解 KCF 的训练机制
人工智能·算法·目标跟踪
2301_795167202 小时前
玩转Rust高级应用 如何理解 Rust 实现免疫数据竞争的关键是Send 和 Sync 这两个 trait
开发语言·算法·rust