免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

LeetCode如何實現二叉搜索樹的范圍和

小編給大家分享一下LeetCode如何實現二叉搜索樹的范圍和,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

我們提供的服務有:成都網站制作、做網站、微信公眾號開發、網站優化、網站認證、高臺ssl等。為超過千家企事業單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的高臺網站制作公司


 

題目描述

給定二叉搜索樹的根結點 root,返回 LR(含)之間的所有結點的值的和。

二叉搜索樹保證具有唯一的值。

示例 1:

輸入:root = [10,5,15,3,7,null,18], L = 7, R = 15輸出:32
 

示例 2:

輸入:root = [10,5,15,3,7,13,18,1,null,6], L = 6, R = 10輸出:23
 

提示:

樹中的結點數量最多為 10000 個。 最終的答案保證小于 2^31


 
 
 
 
-------------------機智的思考線-------------------  
 
 
 
 
-------------------機智的思考線--------------------  
 
 
 
 
-------------------機智的思考線-------------------  
 
 
 
 
   

解題方案

 

思路

  • 標簽:深度優先遍歷

  • 題意:這個題字面含義很難理解,本意就是求出所有 X >= LX <= R 的值的和

  • 遞歸終止條件:

    • 當前節點為null時返回0

    • 當前節點 X < L 時則返回右子樹之和

    • 當前節點 X > R 時則返回左子樹之和

    • 當前節點 X >= LX <= R 時則返回:當前節點值 + 左子樹之和 + 右子樹之和

  • 注意點:通過判斷X的大小能夠避免遍歷全部樹的節點,比如下方的動圖中,3這個值就沒有必要遍歷

LeetCode如何實現二叉搜索樹的范圍和

示例1動圖

 
 

代碼

/** * Definition for a binary tree node. * public class TreeNode { *     int val; *     TreeNode left; *     TreeNode right; *     TreeNode(int x) { val = x; } * } */class Solution {    public int rangeSumBST(TreeNode root, int L, int R) {        if (root == null) {            return 0;        }        if (root.val < L) {            return rangeSumBST(root.right, L, R);        }        if (root.val > R) {            return rangeSumBST(root.left, L, R);        }        return root.val + rangeSumBST(root.left, L, R) + rangeSumBST(root.right, L, R);    }}

看完了這篇文章,相信你對“LeetCode如何實現二叉搜索樹的范圍和”有了一定的了解,如果想了解更多相關知識,歡迎關注創新互聯行業資訊頻道,感謝各位的閱讀!

本文名稱:LeetCode如何實現二叉搜索樹的范圍和
文章網址:http://m.newbst.com/article4/jescoe.html

成都網站建設公司_創新互聯,為您提供響應式網站營銷型網站建設品牌網站建設微信小程序自適應網站App設計

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站建設網站維護公司