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];
    }
};
相关推荐
Miki Makimura3 小时前
基于网络io的多线程TCP服务器
网络·c++·学习
jc06203 小时前
项目实战5:聊天室
c++
草莓熊Lotso3 小时前
《回溯 C++98:string 核心机制拆解 —— 从拷贝策略到高效 swap》
开发语言·c++
Jiezcode4 小时前
LeetCode 55.跳跃游戏
c++·算法·leetcode·游戏
l1t4 小时前
在duckdb 1.4中编译和使用postgresql协议插件duckdb-pgwire
开发语言·数据库·c++·postgresql·插件·duckdb
wheeldown4 小时前
【Leetcode高效算法】用双指针策略打破有效三角形的个数
python·算法·leetcode
scilwb4 小时前
第二周任务:STM32 + 永刚VESC6电调 + N5065电机CAN通信控制
c++·开源·产品
蒙奇D索大4 小时前
【数据结构】考研重点掌握:顺序查找算法实现与ASL计算详解
数据结构·笔记·学习·考研·算法·改行学it
TTGGGFF4 小时前
MATLAB仿真:编程基础实验全解析——从入门到实战
数据结构·算法·matlab