代码随想录 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];
    }
};
相关推荐
橘颂TA13 分钟前
【剑斩OFFER】算法的暴力美学——重排链表
算法·结构与算法
zl_vslam23 分钟前
SLAM中的非线性优-3D图优化之相对位姿Between Factor位姿图优化(十三)
人工智能·算法·计算机视觉·3d
千里马-horse25 分钟前
Rect Native bridging 源码分析--AString.h
c++·ts·rn·jsi
Timmylyx051826 分钟前
CF 新年赛 Goodbye 2025 题解
算法·codeforces·比赛日记
闻缺陷则喜何志丹26 分钟前
【二分查找】P10091 [ROIR 2022 Day 2] 分数排序|普及+
c++·算法·二分查找
only-qi1 小时前
leetcode2. 两数相加
算法·leetcode
鲨莎分不晴1 小时前
拯救暗淡图像:深度解析直方图均衡化(原理、公式与计算)
人工智能·算法·机器学习
DuHz1 小时前
242-267 GHz双基地超外差雷达系统:面向精密太赫兹传感与成像的65nm CMOS实现——论文阅读
论文阅读·物联网·算法·信息与通信·毫米波雷达
AI科技星2 小时前
时空的固有脉动:波动方程 ∇²L = (1/c²) ∂²L/∂t² 的第一性原理推导、诠释与验证
数据结构·人工智能·算法·机器学习·重构
阿豪只会阿巴2 小时前
【多喝热水系列】从零开始的ROS2之旅——Day4
c++·笔记·python·ros2