摘要:每日一題二叉樹的坡度鏈接二叉樹的坡度題目分析簡單的問題。首先明確思路,我們需要遍歷每一個點,然后求出該點左右子樹的值的總和,然后做差,答案累計這個差值即可。
簡單的dfs問題。首先明確思路,我們需要遍歷每一個點,然后求出該點左右子樹的值的總和,然后做差,答案累計這個差值即可。那么問題就轉化到求每個節點左右子樹值的綜合上面,同樣是一個dfs問題,但是這個問題有一個優化,我們在之后的代碼部分進行詳細的分析。
C++
/** * 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 res = 0; int findTilt(TreeNode* root) { // 首先對節點判空,如果是空,那么結果為0,直接返回即可. if(root == nullptr) return res; // 遍歷整個樹 dfs(root); // 返回結果值 return res; } void dfs(TreeNode* root) { // 分別記錄左右子樹值的總和,初始值為0 int l = 0, r = 0; // 如果存在左子樹就更新左子樹值的總和 if(root->left) l = sum(root->left); // 如果存在右子樹就更新右子樹值的總和 if(root->right) r = sum(root->right); // 答案記錄一下差值 res += abs(l - r); // 如果存在左節點就計算左節點的坡度 if(root->left) dfs(root->left); // 如果存在右節點就計算右節點的坡度 if(root->right) dfs(root->right); } int sum(TreeNode* root) { // 計算當前節點值的總和 // 左子樹的值 int l = 0; // 右子樹的值 int r = 0; // 如果存在左子樹就更新左子樹的值(遞歸更新) if(root->left) l = sum(root->left); // 如果存在右子樹就更新右子樹的值(遞歸更新) if(root->right) r = sum(root->right); // 返回當前節點值的總和 return root->val + l + r; }};
C++
優化
我們經過簡單的思考就可以發現,解法一實在是太繁瑣了,我們每遍歷一個點,就需要查詢以當前結點為跟的整個樹,其中存在大量的重復,那么是否可以優化這個過程呢?我們仔細觀察,其實在計算差值的時候,我們也是遍歷了整個樹,那么我們可以可以邊更新邊遍歷,我們先計算底層的值,然后用底層的值來更新更高一層的值,顯然是可以的。
/** * 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 { int res = 0;public: int findTilt(TreeNode* root) { // 如果根節點非空就遞歸遍歷樹 if(root) dfs(root); // 返回結果 return res; } // 邊計算差值邊求當前節點的總和,從底層開始向上遍歷 int dfs(TreeNode* root) { // 如果是葉子,就返回當前值 if(!root->left and !root->right) return root->val; // 計算當前當前節點的左右子樹總和,默認值為0 int l = 0, r = 0; // 如果存在左子樹就更新l,此時,先去計算底層的值,向下遞歸 if(root->left) l = dfs(root->left); // 如果存在右子樹就更新r,此時,先去計算底層的值,向下遞歸 if(root->right) r = dfs(root->right); // 記錄下差值 res += abs(l - r); // 返回當前節點的值的總和 return l + r + root->val; }};
Java
class Solution { int ans = 0; public int findTilt(TreeNode root) { dfs(root); return ans; } public int dfs(TreeNode node) { if (node == null) { return 0; } int sumLeft = dfs(node.left); int sumRight = dfs(node.right); ans += Math.abs(sumLeft - sumRight); return sumLeft + sumRight + node.val; }}作者:LeetCode-Solution
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/123947.html
摘要:解題思路一道非常簡單的題目,不能被繞進去,首先要把題目讀明白,左右坡度差本質上是左右子樹和之差,那么問題就簡單了,每次,返回的就是當前所在子樹之和,更新坡度差的話就是當前左右子樹之差,這兩個要分開來計算,代碼如下 ...
摘要:在線網站地址我的微信公眾號完整題目列表從年月日起,每天更新一題,順序從易到難,目前已更新個題。這是項目地址歡迎一起交流學習。 這篇文章記錄我練習的 LeetCode 題目,語言 JavaScript。 在線網站:https://cattle.w3fun.com GitHub 地址:https://github.com/swpuLeo/ca...我的微信公眾號: showImg(htt...
摘要:每日一題平衡二叉樹鏈接平衡二叉樹題目分析遍歷樹,然后每次判斷樹的左右兩個子樹的差值即可。 leetcode每日一題-110:平衡二叉樹 鏈接 平衡二叉樹 題目 ...
摘要:每日一題叉樹的最大深度鏈接叉樹的最大深度題目分析簡單的搜索題目。只需要從根節點開始一下整個叉樹就可以得到答案了。主要是對要理解和掌握叉樹的遍歷。代碼作者作者 lee...
摘要:有效二叉搜索樹定義如下節點的左子樹只包含小于當前節點的數。所有左子樹和右子樹自身必須也是二叉搜索樹。而我們二叉搜索樹保證了左子樹的節點的值均小于根節點的值,根節點的值均小于右子樹的值,因此中序遍歷以后得到的序列一定是升序序列。 ...
閱讀 3414·2021-11-25 09:43
閱讀 3470·2021-11-19 09:40
閱讀 2473·2021-10-14 09:48
閱讀 1290·2021-09-09 11:39
閱讀 1928·2019-08-30 15:54
閱讀 2828·2019-08-30 15:44
閱讀 2002·2019-08-29 13:12
閱讀 1548·2019-08-29 12:59