zoukankan      html  css  js  c++  java
  • 二叉树中和为某一值的路径 牛客网 程序员面试金典 C++ Python

    二叉树中和为某一值的路径 牛客网 程序员面试金典

    • 题目描述
    • 输入一颗二叉树的跟节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。(注意: 在返回值的list中,数组长度大的数组靠前)

    c++

    /*
    struct TreeNode {
    	int val;
    	struct TreeNode *left;
    	struct TreeNode *right;
    	TreeNode(int x) :
    			val(x), left(NULL), right(NULL) {
    	}
    };*/
    class Solution {
    
    public:
        //run:3ms memory:484k
        vector<vector<int>> FindPath(TreeNode* root, int expectNumber){
            vector<vector<int>> ret;
            vector<int> lt;
            if (NULL == root) return ret;
            return FindAPath(root,expectNumber,ret,lt);
        }
        
        vector<vector<int>> FindAPath(TreeNode* root, int expectNumber, 
                                      vector<vector<int>> &path_list,vector<int> lt){
            if (NULL == root) return path_list;
            expectNumber -= root->val;
            lt.push_back(root->val);
            if (expectNumber != 0){
                FindAPath(root->left,expectNumber,path_list,lt);
                FindAPath(root->right,expectNumber,path_list,lt);
            }else if(NULL == root->left && NULL == root->right)
                path_list.push_back(lt);
            return path_list;
        }
        
        //run:3ms memory:480k
        vector<vector<int> > FindPath2(TreeNode* root,int expectNumber){
            if(root) dfsFind(root, expectNumber);
            return allRes;
        }
         
        void dfsFind(TreeNode * node , int target){
            tmp.push_back(node->val);
            if(!node->left && !node->right){
                if(target - node->val == 0) allRes.push_back(tmp);
            }else{
                if(node->left) dfsFind(node->left, target - node->val);
                if(node->right) dfsFind(node->right, target - node->val);
            }
             
            if(!tmp.empty())
                tmp.pop_back();
        }
        private:
            vector<vector<int> >allRes;
            vector<int> tmp;
    };

    Python

    # class TreeNode:
    #     def __init__(self, x):
    #         self.val = x
    #         self.left = None
    #         self.right = None
    class Solution:
        # run:32ms memory:5736k
        def FindPath(self, root, expectNumber):
            if None == root: return []
            return self.FindAPath(root,expectNumber,[],[])
        
        def FindAPath(self,root,expectNumber,path_list,lt):
            if None == root: return 
            expectNumber = expectNumber - root.val
            lt.append(root.val)
            if expectNumber !=0:
                left_lt = list(lt)
                self.FindAPath(root.left,expectNumber,path_list,left_lt)
                right_lt = list(lt)
                self.FindAPath(root.right,expectNumber,path_list,right_lt)
            elif root.left == None and root.right == None:
                path_list.append(lt)
            return path_list
  • 相关阅读:
    net core 2 读取appsettings.json
    转: C# 根据当前时间获取,本周,本月,本季度等时间段 .Net中Exception
    转:5种回到顶部的写法从实现到增强
    转:jQuery 常见操作实现方式
    NLog 自定义字段 写入 oracle
    转:C# 使用NLog记录日志
    转:NLog之:文件类型目标(File target)
    springboot2.x+jwt+shiro最简单、最快速整合方式
    windows部署mindoc
    docker安装mongodb
  • 原文地址:https://www.cnblogs.com/vercont/p/10210337.html
Copyright © 2011-2022 走看看