1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
|
class Solution { private: int n = 0; void dfs(TreeNode *root) { n += 1; if(root->left) dfs(root->left); if(root->right) dfs(root->right); } public: int countNodes(TreeNode* root) { if(!root) return n; dfs(root); return n; }
int countNodes(TreeNode *root) { if(!root) { return 0; } int left = countLevel(root->left); int right = countLevel(root->right);
if(left == right) return countNodes(root->right) + (1 << left); else return countNodes(root->left) + (1 << right); }
int countLevel(TreeNode *root) { if(!root) return 0; int level = 0; while(root) { ++level; root = root->left; } return level; } };
class Solution{ public: int countNodes(TreeNode *root) { if(!root) return 0; return countNodes(root->left) + countNodes(root->right) + 1; } };
|