두 갈래 트리 중 한 경로에 대한 값(DFS)

112 Path Sum은 두 갈래 나무와 하나의 합을 지정하여 나무에 뿌리에서 잎까지의 경로가 있는지 확인하여 경로를 따라 합친 모든 값이 주어진 총계와 같도록 합니다.https://leetcode.com/problems/path-sum/description/
bool hasPathSum(TreeNode* root, int sum) {
        if(root == nullptr)
            return false;
        if(root->val == sum && root->left == NULL && root->right == NULL)
            return true;
        return hasPathSum(root->left, sum - root->val) || hasPathSum(root->right, sum - root->val);            
    }

두 갈래 나무 중화는 가치 있는 경로이다
두 갈래 트리와 정수를 입력하고 두 갈래 트리의 결점 값과 정수를 입력하기 위한 모든 경로를 출력합니다.경로는 나무의 뿌리 결점에서 시작하여 잎 결점까지 내려가는 결점으로 경로를 형성합니다.https://www.nowcoder.com/practice/b736e784e3e34731af99065031301bca?tpId=13&tqId=11177&tPage=2&rp=2&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking
void DFS(TreeNode *root, int sum, vector<int> &path, vector<vector<int>> &paths) {
    // 、 nullptr, 
    if (root == nullptr)
        return;
    path.push_back(root->val);
    if (root->left == nullptr && root->right == nullptr && root->val == sum)
        paths.push_back(path);
    DFS(root->left, sum - root->val, path, paths);
    // nullptr, return; 
    DFS(root->right, sum - root->val, path, paths);
    // 
    path.pop_back();
}

vector<vector<int> > FindPath(TreeNode* root, int expectNumber) {
    vector<vector<int>> paths;
    vector<int> path;
    DFS(root, expectNumber, path, paths);
    return paths;
}

또는
  void DFS(TreeNode *root, int sum, vector<int> path, vector<vector<int>> &paths){
        if(root == nullptr)
            return;
        path.push_back(root->val);
        if(root->left == nullptr && root->right == nullptr && root->val == sum)
            paths.push_back(path);
        DFS(root->left, sum - root->val, path, paths);
        DFS(root->right, sum - root->val, path, paths);        
    }
 vector<vector<int> > FindPath(TreeNode* root,int expectNumber) {  
        vector<vector<int>> paths;
        vector<int> path;        
        DFS(root, expectNumber, path, paths);
        return paths;  
        }

동일:https://leetcode.com/problems/binary-tree-paths/description/

좋은 웹페이지 즐겨찾기