LeetCode 563二叉树的坡度-简单
給定一個二叉樹,計算 整個樹 的坡度 。
一個樹的 節點的坡度 定義即為,該節點左子樹的節點之和和右子樹節點之和的 差的絕對值 。如果沒有左子樹的話,左子樹的節點之和為 0 ;沒有右子樹的話也是一樣??战Y點的坡度是 0 。
整個樹 的坡度就是其所有節點的坡度之和。
示例 1:
輸入:root = [1,2,3]
輸出:1
解釋:
節點 2 的坡度:|0-0| = 0(沒有子節點)
節點 3 的坡度:|0-0| = 0(沒有子節點)
節點 1 的坡度:|2-3| = 1(左子樹就是左子節點,所以和是 2 ;右子樹就是右子節點,所以和是 3 )
坡度總和:0 + 0 + 1 = 1
示例 2:
輸入:root = [4,2,9,3,5,null,7]
輸出:15
解釋:
節點 3 的坡度:|0-0| = 0(沒有子節點)
節點 5 的坡度:|0-0| = 0(沒有子節點)
節點 7 的坡度:|0-0| = 0(沒有子節點)
節點 2 的坡度:|3-5| = 2(左子樹就是左子節點,所以和是 3 ;右子樹就是右子節點,所以和是 5 )
節點 9 的坡度:|0-7| = 7(沒有左子樹,所以和是 0 ;右子樹正好是右子節點,所以和是 7 )
節點 4 的坡度:|(3+5+2)-(9+7)| = |10-16| = 6(左子樹值為 3、5 和 2 ,和是 10 ;右子樹值為 9 和 7 ,和是 16 )
坡度總和:0 + 0 + 0 + 2 + 7 + 6 = 15
示例 3:
輸入:root = [21,7,14,1,1,2,2,3,3]
輸出:9
提示:
樹中節點數目的范圍在 [0, 10^4] 內 -1000 <= Node.val <= 1000代碼如下:
/*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/ class Solution { public:int ans = 0;int findTilt(TreeNode* root) {pdsum(root);return ans;} public:int pdsum(TreeNode *root){if (root==nullptr) return 0;int left_sum = pdsum(root->left);int right_sum = pdsum(root->right);ans +=abs(left_sum-right_sum);return left_sum+right_sum+root->val;} };總結
以上是生活随笔為你收集整理的LeetCode 563二叉树的坡度-简单的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 7天辟谷减肥正确方法是什么
- 下一篇: 5点后不吃东西,每天运动半小时可以减肥吗