【LeetCode】【0-1背包】目标和

题目链接:494. 目标和 - 力扣(LeetCode)

要在数组中通过加减元素得到目标和,记加的元素和为x,减的元素和为y,即x-y=target

又因为x+y=sum,两式相加,可以求得x=(target+sum)/2,即题目变成能不能在元素里面找到一个组合的和为x,即0-1背包问题,基本同【LeetCode】【0-1背包】分割等和子集-CSDN博客

dp[i]变成存在子集和为i的个数

注意如果target+sum不是偶数或者target的绝对值大于sum都是没有的

复制代码
class Solution {
public:
    int findTargetSumWays(vector<int> &nums, int target) {
        int sum = 0;
        for (auto &num: nums)sum += num;
        if (sum + target & 1 || abs(target) > sum)return 0;
        int x = (sum + target) / 2;
        vector<int> dp(x + 1);
        dp[0] = 1;
        for (auto &num: nums)
            for (int i = x; i >= num; --i)
                dp[i] += dp[i - num];
        return dp[x];
    }
};
相关推荐
aini_lovee13 分钟前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong999021 分钟前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语50522 分钟前
深入理解主成分分析(PCA)
算法
apollowing24 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app
晚枫歌F28 分钟前
最小堆定时器
数据结构·算法
Lumos_7771 小时前
Linux -- 线程
java·jvm·算法
七颗糖很甜1 小时前
“十五五”气象发展规划:聚焦五大核心任务
大数据·python·算法
科研前沿2 小时前
镜像视界浙江科技有限公司的关键技术突破有哪些?
大数据·人工智能·科技·算法·音视频·空间计算
嫩萝卜头儿2 小时前
2 - 复杂度收尾 + 链表经典OJ
数据结构·算法·链表·复杂度
星马梦缘2 小时前
算法设计与分析 作业二 答案与解析
算法·图论·dfs·bfs·floyd-warshall·bellman_ford·多源最短路