zoukankan      html  css  js  c++  java
  • 剑指offer | 二叉树中和为某一值的路径 | 30


    思路分析

    就是DFS,然后到达叶子结点的时候就判断是否满足条件,如果满足的话就是一个答案.

    cpp

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
    
        vector<vector<int>> ans;
        vector<int> path;
    
        void dfs(TreeNode* root,int sum){
            if(!root)return;
            sum -= root->val;
            path.push_back(root->val);
            if(!root->left && !root->right && !sum)ans.push_back(path);
            dfs(root->left,sum);
            dfs(root->right,sum);
            path.pop_back();
    
    
        }
    
        vector<vector<int>> pathSum(TreeNode* root, int sum) {
            dfs(root,sum);
            return ans;
        }
    };
    

    python

    # Definition for a binary tree node.
    # class TreeNode:
    #     def __init__(self, x):
    #         self.val = x
    #         self.left = None
    #         self.right = None
    
    class Solution:
        def pathSum(self, root: TreeNode, sum: int) -> List[List[int]]:
            ans = []
            path = []
    
            def dfs(root,sum):
                if not root:return
                sum -= root.val
                path.append(root.val)
                if not root.left and not root.right and not sum:
                    ans.append(list(path))
                dfs(root.left,sum)
                dfs(root.right,sum)
                path.pop()
            
            dfs(root,sum)
            return ans
    
  • 相关阅读:
    《大道至简》读后有感
    关于jQuery放置位置的问题01
    javascript基础
    层叠样式表与css3基础
    经典sql语句
    java开发中的23种设计模式
    struts2漏洞以及测试
    离开贴吧大概会写下博客吧
    Set介绍
    小知识点
  • 原文地址:https://www.cnblogs.com/Rowry/p/14335545.html
Copyright © 2011-2022 走看看