leetcode 494 目标和

一、题目描述

二、解题思路

整体思路

画出本题的决策树,可以采用回溯的方法来解决这个问题。

具体思路

(1)函数功能:dfs函数用于统计从start开始,表达式值为target的表达式的所有个数;

(2)递归出口:当start等于nums.size()时,若表达式的值为target,则ret++。不论表达式的值是否为target,都需要返回;

(3)函数体:当前位置要么选择'+',要么选择'-',根据这两种情况来解决

<1>选择'+',path+=nums[i],dfs处理后一个位置,处理完后恢复现场;

<2>选择'-',path+=nums[i],dfs处理后一个位置,处理完后恢复现场;

注意只有修改了全局变量的值,才需要进行回溯恢复现场。

三、代码实现

cpp 复制代码
class Solution {
    int ret=0;
    int path=0;
public:
    int findTargetSumWays(vector<int>& nums, int target) {
        dfs(nums,0,target);
        return ret;
    }
    void dfs(vector<int>& nums,int start,int target){
        //递归出口
        if(start==nums.size()){
            if(path==target){
                ret++;
            }
            return ;
        }
            //选'+'
            path+=nums[start];
            dfs(nums,start+1,target);
            //恢复现场
            path-=nums[start];

            //选'-'
            path-=nums[start];
            dfs(nums,start+1,target);
            //恢复现场
            path+=nums[start];
    }
};
相关推荐
iuu_star15 小时前
C语言数据结构-顺序查找、折半查找
c语言·数据结构·算法
优雅的潮叭15 小时前
c++ 学习笔记之 malloc
c++·笔记·学习
Yzzz-F15 小时前
P1558 色板游戏 [线段树 + 二进制状态压缩 + 懒标记区间重置]
算法
漫随流水16 小时前
leetcode算法(515.在每个树行中找最大值)
数据结构·算法·leetcode·二叉树
mit6.82416 小时前
dfs|前后缀分解
算法
扫地的小何尚17 小时前
NVIDIA RTX PC开源AI工具升级:加速LLM和扩散模型的性能革命
人工智能·python·算法·开源·nvidia·1024程序员节
苦藤新鸡18 小时前
8.最长的无重复字符的子串
c++·力扣
千金裘换酒18 小时前
LeetCode反转链表
算法·leetcode·链表
꧁Q༒ོγ꧂18 小时前
C++ 入门完全指南(四)--函数与模块化编程
开发语言·c++
byzh_rc18 小时前
[认知计算] 专栏总结
线性代数·算法·matlab·信号处理