검지offer: 두 갈래 트리 중 어느 값의 경로

3345 단어 검지offer
제목 설명: 두 갈래 트리와 정수를 입력하고 두 갈래 트리의 결점 값과 정수를 입력하기 위한 모든 경로를 출력합니다.경로는 나무의 뿌리 결점에서 시작하여 잎 결점까지 내려가는 결점으로 경로를 형성합니다.
분석: 경로는 나무의 뿌리 결점에서 잎 결점까지 내려가는 결점으로 정의되어 하나의 경로를 형성한다.귀착된 사상으로 분해하다
코드 구현:
#include 
#include 
using namespace std;

typedef struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
    TreeNode(int x) :
            val(x), left(NULL), right(NULL) {
    }
}Node;

class Solution {
public:
    vector<vector<int> > buffer;
    vector<int> tmp;
    vector<vector<int> > FindPath(TreeNode* root,int expectNumber) {
        if(root==NULL)
            return buffer;
        tmp.push_back(root->val);
        if((expectNumber-root->val)==0 && root->left==NULL && root->right==NULL)
            {
            buffer.push_back(tmp);
        }
        FindPath(root->left,expectNumber-root->val);
        FindPath(root->right,expectNumber-root->val);
        if(tmp.size()!=0)
            tmp.pop_back();
        return buffer;
    }
};

int main()
{
    Node *tmp ;
    Node* root = new Node(10);
    tmp = new Node(5);
    root->left = tmp ;
    tmp = new Node(12);
    root->right = tmp;
    tmp = new Node(4);
    root->left->left = tmp;
    tmp = new Node(7);
    root->left->right = tmp;
    vector<vector<int>> ret;
    Solution s;
    ret = s.FindPath(root,22); 
    return 0;
} 

좋은 웹페이지 즐겨찾기