【LeetCode494】目标和(暴搜dfs或dp)

简介: 1 <= nums.length <= 200 <= nums[i] <= 1000

一、题目

image.png

提示:


1 <= nums.length <= 20

0 <= nums[i] <= 1000

0 <= sum(nums[i]) <= 1000

-1000 <= target <= 1000

二、思路

暴搜dfs基础题。

(1)一开始很傻把k==nums.size())和cur_res == target两个条件写一块判断了,其实要分开判断,因为即使cur_res == target不满足,最后也是要return的;

(2)注意在dfs中的参数不能写成k++,不符合逻辑,最后也会导致数组越界,报错stack overflow(一般是数组越界或者空指针才会这样报错),血的教训~


三、代码

class Solution {
    int method_num = 0;
public:
    int findTargetSumWays(vector<int>& nums, int target) {
        dfs(nums, 0, target, 0);
        return method_num;
    }
    void dfs(vector<int>& nums, int k, int target, int cur_res){
        if(k == nums.size()){
            if(cur_res == target){
                method_num += 1;
            }
            return;
        }
        dfs(nums, k + 1, target, cur_res + nums[k]);
        dfs(nums, k + 1, target, cur_res - nums[k]);
    }
};
相关文章
|
3月前
|
Python
【Leetcode刷题Python】494. 目标和
LeetCode 494题 "目标和" 的Python解决方案,通过动态规划算法计算在给定整数数组和目标值的情况下,可以构造多少种不同表达式使得运算结果等于目标值。
37 3
|
5月前
|
存储 算法 数据挖掘
python 数学+减治、下一个排列法、DFS回溯法实现:第 k 个排列【LeetCode 题目 60】
python 数学+减治、下一个排列法、DFS回溯法实现:第 k 个排列【LeetCode 题目 60】
|
6月前
|
算法
【优选算法】——Leetcode——LCR 179. 查找总价格为目标值的两个商品
【优选算法】——Leetcode——LCR 179. 查找总价格为目标值的两个商品
|
5月前
【LeetCode刷题】有效三角形个数、查找总价值为目标值的两个商品
【LeetCode刷题】有效三角形个数、查找总价值为目标值的两个商品
|
5月前
|
算法
【经典LeetCode算法题目专栏分类】【第9期】深度优先搜索DFS与并查集:括号生成、岛屿问题、扫雷游戏
【经典LeetCode算法题目专栏分类】【第9期】深度优先搜索DFS与并查集:括号生成、岛屿问题、扫雷游戏
|
5月前
|
存储 SQL 算法
LeetCode题目100:递归、迭代、dfs使用栈多种算法图解相同的树
LeetCode题目100:递归、迭代、dfs使用栈多种算法图解相同的树
|
6月前
[leetcode~dfs]1261. 在受污染的二叉树中查找元素
[leetcode~dfs]1261. 在受污染的二叉树中查找元素
[leetcode~dfs]1261. 在受污染的二叉树中查找元素
|
6月前
|
算法
每日一题:LeetCode-LCR 179. 查找总价格为目标值的两个商品
每日一题:LeetCode-LCR 179. 查找总价格为目标值的两个商品
【Leetcode -733.图像渲染 -744.寻找比目标字母大的最小字母】
【Leetcode -733.图像渲染 -744.寻找比目标字母大的最小字母】
38 0
|
6月前
|
算法 定位技术
【leetcode】剑指 Offer II 105. 岛屿的最大面积-【深度优先DFS】
【leetcode】剑指 Offer II 105. 岛屿的最大面积-【深度优先DFS】
72 0