diff options
| author | crupest <crupest@outlook.com> | 2020-08-12 23:50:08 +0800 | 
|---|---|---|
| committer | crupest <crupest@outlook.com> | 2020-08-12 23:50:08 +0800 | 
| commit | 4bcfcaf0304c632cd2fe4de68e8cf09602a4ec9b (patch) | |
| tree | 675eab1cf2f7b5cd5b05f84776713573fda0ff96 /works/solutions/cpp | |
| parent | 1bba4209221b435db8ed6d21db1cb57d84acc3bc (diff) | |
| download | crupest-4bcfcaf0304c632cd2fe4de68e8cf09602a4ec9b.tar.gz crupest-4bcfcaf0304c632cd2fe4de68e8cf09602a4ec9b.tar.bz2 crupest-4bcfcaf0304c632cd2fe4de68e8cf09602a4ec9b.zip | |
import(solutions): Add problem 337 .
Diffstat (limited to 'works/solutions/cpp')
| -rw-r--r-- | works/solutions/cpp/337.cpp | 38 | 
1 files changed, 38 insertions, 0 deletions
| diff --git a/works/solutions/cpp/337.cpp b/works/solutions/cpp/337.cpp new file mode 100644 index 0000000..655a4d0 --- /dev/null +++ b/works/solutions/cpp/337.cpp @@ -0,0 +1,38 @@ +#include <cstddef>
 +
 +struct TreeNode
 +{
 +    int val;
 +    TreeNode *left;
 +    TreeNode *right;
 +    TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 +};
 +
 +struct SubTreeResult
 +{
 +    SubTreeResult(int use_root, int not_use_root) : use_root(use_root), not_use_root(not_use_root), max(use_root > not_use_root ? use_root : not_use_root) {}
 +
 +    const int use_root;
 +    const int not_use_root;
 +    const int max;
 +};
 +
 +class Solution
 +{
 +public:
 +    static SubTreeResult subtree_rob(TreeNode *root)
 +    {
 +        SubTreeResult left = root->left != NULL ? subtree_rob(root->left) : SubTreeResult{0, 0};
 +        SubTreeResult right = root->right != NULL ? subtree_rob(root->right) : SubTreeResult{0, 0};
 +        const auto use_root_value = root->val + left.not_use_root + right.not_use_root;
 +        const auto not_use_root_value = left.max + right.max;
 +        return SubTreeResult{use_root_value, not_use_root_value};
 +    }
 +
 +    int rob(TreeNode *root)
 +    {
 +        if (root == NULL)
 +            return 0;
 +        return subtree_rob(root).max;
 +    }
 +};
 | 
