LeetCode-98. 驗證二叉搜索樹

一、題目

給定一個二叉樹,判斷其是否是一個有效的二叉搜索樹。假設一個二叉搜索樹具有如下特征:

若它的左子樹不空,則左子樹上所有結點的值均小于它的根結點的值;
若它的右子樹不空,則右子樹上所有結點的值均大于它的根結點的值;
它的左、右子樹也分別為二叉排序樹。

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

二、解答

// 方法1// 前一個節點TreeNode pre = new TreeNode();public boolean isValidBST1(TreeNode root) {// 對數進行中序遍歷,如果結果是遞增,則代表是有效二叉搜索樹;否則,不是// 不用比較全部節點,只需要比較當前節點和前一個節點即可。// 如果當前節點值小于前一個節點,則不是有效二叉搜索樹;否則,是。// 遞歸判斷左子樹,然后判斷當前節點和上一個節點值,最后遞歸判斷右子樹。if(root == null){return true;}if(!isValidBST1(root.left)){return false;}// 如果當前節點值小于前一個節點,則不是有效二叉搜索樹;if(pre != null && pre.val >= root.val){return false;}// 更新前一個節點為當前節點pre = root;return isValidBST1(root.right);}// 方法2public boolean isValidBST2(TreeNode root) {return checkValidBST(root, null, null);}/* 限定以 root 為根的子樹節點必須滿足 max.val > root.val > min.val */boolean checkValidBST(TreeNode root, TreeNode min, TreeNode max) {if(root == null){return true;}// 若 root.val 不符合 max 和 min 的限制,說明不是合法 BSTif( min != null && root.val <= min.val){return false;}if(max!= null && root.val >= max.val){return false;}// 限定左子樹的最大值是 root.val,右子樹的最小值是 root.valreturn checkValidBST(root.left,min,root) && checkValidBST(root.right,root,max);}public class TreeNode {int val;TreeNode left;TreeNode right;TreeNode() {}TreeNode(int val) {this.val = val;}TreeNode(int val, TreeNode left, TreeNode right) {this.val = val;this.left = left;this.right = right;}}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/76819.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/76819.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/76819.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Python菜鳥教程(小程序)

目錄 一.簡易計算器 二.學生成績分級 三.密碼設置 四.作業選擇 點贊收藏,評論支持 一.簡易計算器 print(-------使用的運算符-------\n) print(1.加號) print(2.減號) print(3.乘號) print(4.除號) Aint(input(請輸入第一個數: )) Bint(input(請輸入第二個數: )) Fi…

Golang的Goroutine(協程)與runtime

目錄 Runtime 包概述 Runtime 包常用函數 1. GOMAXPROCS 2. Caller 和 Callers 3. BlockProfile 和 Stack 理解Golang的Goroutine Goroutine的基本概念 特點&#xff1a; Goroutine的創建與啟動 示例代碼 解釋 Goroutine的調度 Gosched的作用 示例代碼 輸出 解…

Dubbo(30)如何配置Dubbo的服務分片?

配置Dubbo的服務分片&#xff08;也稱為服務分組&#xff09;可以幫助你將不同的服務實例分組&#xff0c;以實現隔離和管理。通過服務分片&#xff0c;可以在同一個注冊中心中注冊多個相同接口的服務&#xff0c;但它們屬于不同的分組&#xff0c;消費者可以根據需要選擇特定分…

文檔的預解析

1. 預解析的核心目標 瀏覽器在正式解析&#xff08;Parsing&#xff09;HTML 前&#xff0c;會啟動一個輕量級的 預解析器&#xff08;Pre-Parser&#xff09;&#xff0c;快速掃描文檔內容&#xff0c;實現&#xff1a; 提前發現并加載關鍵資源&#xff08;如 CSS、JavaScrip…

通過構造函數和幾何條件,研究了不同函數的最近點存在性、性質及單調性

解&#xff1a; &#xff08;1&#xff09;對于函數 f ( x ) 1 x f(x) \frac{1}{x} f(x)x1? 和點 M ( 1 , 0 ) M(1, 0) M(1,0)&#xff0c;構造函數 s ( x ) ( x ? 1 ) 2 ( 1 x ) 2 s(x) (x - 1)^2 \left(\frac{1}{x}\right)^2 s(x)(x?1)2(x1?)2。求導得到 s ′ …

C語言之編譯和debug工具

gcc gcc是GUN項目為C和C提供的編譯器 入門案例 gcc編譯器最簡單的使用案例&#xff1a;gcc hello.c -o hello&#xff0c;hello.c是源文件&#xff0c;-o參數指定了結果文件的名稱 gcc命令的選項&#xff1a; -v&#xff1a;打印編譯細節-E&#xff1a;僅僅進行預處理&…

Altshuller矛盾矩陣查詢:基于python和streamlit

基于python和streamlit實現的Altshuller矛盾矩陣查詢 import streamlit as st import json# 加載數據 st.cache_resource def load_data():with open(parameter.json, encodingutf-8) as f:parameters json.load(f)with open(way.json, encodingutf-8) as f:contradictions …

Maven的下載配置及在Idea中的配置

編寫項目管理中存在的問題 在大型Java項目開發中&#xff0c;依賴管理是一個極其復雜的挑戰。傳統方式下&#xff0c;開發者需要手動下載并引入數十甚至上百個JAR包到項目中&#xff0c;這一過程不僅繁瑣低效&#xff0c;還存在諸多痛點&#xff1a; 依賴傳遞性問題&#xff1a…

來聊聊C++中的vector

一.vector簡介 vector是什么 C 中的 vector 是一種序列容器&#xff0c;它允許你在運行時動態地插入和刪除元素。 vector 是基于數組的數據結構&#xff0c;但它可以自動管理內存&#xff0c;這意味著你不需要手動分配和釋放內存。 與 C 數組相比&#xff0c;vector 具有更多的…

WVP-GB28181攝像頭管理平臺存在弱口令

免責聲明&#xff1a;本號提供的網絡安全信息僅供參考&#xff0c;不構成專業建議。作者不對任何由于使用本文信息而導致的直接或間接損害承擔責任。如涉及侵權&#xff0c;請及時與我聯系&#xff0c;我將盡快處理并刪除相關內容。 漏洞描述 攻擊者可利用漏洞獲取當前系統管…

訊飛語音聽寫(流式版)開發指南

語音交互大模型的功能越來越受到重視。訊飛語音聽寫&#xff08;流式版&#xff09;為開發者提供了一種高效、準確的語音識別解決方案。本文將基于 Home.vue、iat_xfyun.js 和 sparkChat.js 這三個文檔&#xff0c;詳細闡述訊飛語音聽寫&#xff08;流式版&#xff09;的開發邏…

基于kotlin native的C與kotlin互相調用

本文測試環境為ubuntu&#xff0c;沒有使用IDE&#xff1b;從基本層面了解kotlin native環境中&#xff0c;C和kotlin的編譯&#xff0c;互相調用。 1. kotlin 動態庫 1.1 動態庫編譯 源碼文件libktest.kt&#xff1a; //file name:libktest.kt OptIn(kotlin.experimental.…

【教學類-102-02】自制剪紙圖案(留白邊、沿線剪)02——Python+PS自動化添加虛線邊框

背景需求: 01版本實現了對透明背景png圖案邊界線的擴展,黑線實線描邊 【教學類-102-01】自制剪紙圖案(留白邊、沿線剪)01-CSDN博客文章瀏覽閱讀974次,點贊15次,收藏7次。【教學類-102-01】自制剪紙圖案(留白邊、沿線剪)01https://blog.csdn.net/reasonsummer/article…

Python-函數參數

1. 參數基礎 函數參數是向函數傳遞數據的主要方式&#xff0c;Python 提供了多種參數傳遞機制。 基本用法 def greet(name): # name 是形式參數print(f"Hello, {name}!")greet("Alice") # "Alice" 是實際參數使用場景&#xff1a;當函數需要…

《在 Ubuntu 22.04 上安裝 CUDA 11.8 和 Anaconda,并配置環境變量》

安裝 CUDA 11.8 和 Anaconda 并配置環境變量 在本教程中&#xff0c;我們將介紹如何在 Ubuntu 22.04 上安裝 CUDA 11.8 和 Anaconda&#xff0c;并配置相應的環境變量。我們還將配置使用 阿里云鏡像源 來加速軟件包更新。以下是具體步驟。 步驟 1&#xff1a;更新軟件源 首先…

Ubuntu環境基于Ollama部署DeepSeek+Open-Webui實現本地部署大模型-無腦部署

Ollama介紹 Ollama是一款簡單好用的模型部署工具,不僅可以部署DeepSeek,市面上開源模型大部分都可以一鍵部署,這里以DeepSeek為例 官網 DeepSeek 版本硬件要求 安裝Ollama 環境 sudo apt update sudo apt install curl sudo apt install lsof1.命令一鍵安裝 在官網點擊…

Angular 項目 PDF 批注插件庫在線版 API 示例教程

本文章介紹 Angular 項目中 PDF 批注插件庫 ElasticPDF 在線版 API 示例教程&#xff0c;API 包含 ① 導出批注后PDF數據&#xff1b;② 導出純批注 json 數據&#xff1b;③ 加載舊批注&#xff1b;④ 切換文檔&#xff1b;⑤ 切換用戶&#xff1b;⑥ 清空批注 等數據處理功能…

Spring Boot 中利用 Jasypt 實現數據庫字段的透明加密解密

1. 引言 1.1 什么是 Jasypt Jasypt(Java Simplified Encryption)是一個用于簡化 Java 應用程序中加密操作的庫。 1.2 為什么使用 Jasypt 簡化加密操作:提供簡單的 API 進行加密和解密。透明加密:自動處理加密和解密過程,無需手動干預。多種加密算法:支持多種加密算法,…

Linux的: /proc/sys/net/ipv6/conf/ 筆記250405

Linux的: /proc/sys/net/ipv6/conf/ /proc/sys/net/ipv6/conf/ 是 Linux 系統中用于 動態配置 IPv6 網絡接口參數 的核心目錄。它允許針對不同網絡接口&#xff08;如 eth0、wlan0&#xff09;或全局設置&#xff08;all&#xff09;調整 IPv6 協議棧的行為。 它通過虛擬文件系…

Spring Cloud 框架為什么能處理高并發

Spring Cloud框架能夠有效處理高并發場景&#xff0c;核心在于其微服務架構設計及多組件的協同作用&#xff0c;具體機制如下&#xff1a; 一、分布式架構設計支撐高擴展性 服務拆分與集群部署 Spring Cloud通過微服務拆分將單體系統解耦為獨立子服務&#xff0c;每個服務可獨…