Path SumII|leetcode题解

本文介绍了一种基于树的先序遍历算法,用于寻找所有根节点到叶子节点路径上的节点值之和等于指定值的路径。通过递归方式实现,并详细展示了如何更新路径与递归终止条件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这题使用树的先序遍历,同时存储路径就可以解决。

    void preOrder(vector<vector<int> >&paths,TreeNode *root, int sum, vector<int>&path,int level){
       if(NULL==root->left&&NULL==root->right){
            if(sum==root->val){
                path.push_back(root->val);
                paths.push_back(path);
            }
            return;
        }
        //if(sum<=root->val)return;
        sum-=root->val;
        path.push_back(root->val);
        if(root->left)preOrder(paths,root->left,sum,path,level+1);     
        path.resize(level);//访问由子树前,恢复path状态
        if(root->right)preOrder(paths,root->right,sum,path,level+1);  
    }

    vector<vector<int> > pathSum(TreeNode *root, int sum) {
        vector<vector<int> >paths;
        if(NULL==root) return paths;
        vector<int>path; 
        preOrder(paths,root,sum,path,1);
        return paths;

    }
写递归函数时,要注意递归函数的出口和调用递归函数时的状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值