java算法day16

java算法day16

  • 112 路徑總和
  • 404 左葉子之和
  • 513 找樹左下角的值

112 路徑總和

題型判定為自頂向下類型,并且為路徑和類型。
那就套模板。
自頂向下就是從上到下處理,那么就是前序遍歷的思想。

class Solution {boolean res = false;public boolean hasPathSum(TreeNode root, int targetSum) {//特判if(root==null&&targetSum==0){return false;}//遞歸dfs(root,targetSum);return res;}//遞歸void dfs(TreeNode root,int targetSum){if(root==null){return;}//過程就是不斷往下遞歸,成功的條件是葉子節點,targetSum-=root.val;if(root.left==null && root.right==null & targetSum==0){res = true;}else{//遞歸左右子樹dfs(root.left,targetSum);dfs(root.right,targetSum);}}
}

本題得到的知識。
因為我是按模板做的,這個題我非常想在遇到結果的時候就立即返回。但是用模板做,那肯定會把全局走完。因此新知識就是怎么實現立即返回。

class Solution {public boolean hasPathSum(TreeNode root, int targetSum) {if(root==null&&targetSum==0){return false;}return dfs(root,targetSum);}boolean dfs(TreeNode root,int targetSum){if(root==null){return false;}targetSum-=root.val;if(root.left==null && root.right==null & targetSum==0){//完全可以直接返回return true;}//核心思想在理解這里return dfs(root.left,targetSum) || dfs(root.right,targetSum);}
}

通過這個題,我對遞歸的理解又更近了一步,更新我的想法。
return dfs(root.left,targetSum) || dfs(root.right,targetSum);
這里的正確想法是,遞歸左右子樹,實際上是遞歸到最左底層后,往上回溯一層,然后才是去遞歸右子樹。所以根據短路操作,碰到返回true,那么反饋給上層,上層得到這個true,就會把還沒遞歸的右子樹給短路。實現了建制。要是按我之前的做法,回溯的過程,每個右子樹都是會去遞歸的。在某些大型樹的場景就效率低了。


404 左葉子之和

這題就兩個難點,左葉子點怎么定義。如果你對什么是左葉子點很清楚,那這個題就很容易。

ps:千萬別層序遍歷去做,層序遍歷根本判別不了葉子節點是左葉子節點還是右葉子節點

1、左葉子點:某點的左孩子節點,其左孩子節點的左右孩子都為null,那么這個節點就是左葉子點。

2、在遞歸的時候很容易空指針,如何解決?
用短路操作把容易空指針的提前斷掉。

先序遍歷的思想

class Solution {int sum = 0;public int sumOfLeftLeaves(TreeNode root) {dfs(root);return sum;}void dfs(TreeNode root){if(root==null){return ;}//這里就是我的短路操作,左葉子節點肯定不是往右走的,所以只用判左邊是否為空。如果左邊都為空了,那么結果不可能在那邊。所以就不用執行后序的操作。if(root.left!=null&&root.left.left==null && root.left.right==null){sum+=root.left.val;}dfs(root.left);dfs(root.right);}
}

513 找樹左下角的值

樹左下角的值,題目給的定義就是,最后一層,最左的節點。

所以我當時就立馬想到了層序遍歷的做法,我在迭代每一層的元素的時候,每次把每一層的第一個元素的值存下來還是很容易的。因此馬上做了出來。

class Solution {public int findBottomLeftValue(TreeNode root) {Deque<TreeNode> que = new ArrayDeque<>();que.offerLast(root);int res = 0;while(!que.isEmpty()){int size = que.size();//每次擴展的時候,只存第一個擴展節點的值,全部處理完,結果就是這個for(int i = 0;i<size;i++){TreeNode temp = que.pollFirst();//關鍵就在這,每層處理一下第一個節點。if(i==0){res = temp.val;}if(temp.left!=null){que.offerLast(temp.left);}if(temp.right!=null){que.offerLast(temp.right);}}}return res;}
}

我提交之后發現,效率可以說非常的低。

遞歸解法:
要點:
1、實際上轉化成了找深度最深的節點。
2、由于要保證最左,那遞歸的時候肯定優先遞歸左邊,所以可以用先序遍歷。

過程中的難點:
1、我在過程中老是在想一找到就立刻返回。實際上這是不太現實的。因為路沒走完,你根本不可能知道哪個節點才是最深的。因此這個過程應該是不斷的尋找最深節點,一旦找到更深的節點,那就應該把該點的值存下來。
2、起點深度怎么定其實無所謂的,最重要的是往下迭代深度的過程。所以一開始設置maxDepth=-1就行了,result=0。那么起點就一定要把maxDepth覆蓋。

class Solution {int maxDepth = -1;int result = 0;public int findBottomLeftValue(TreeNode root) {dfs(root,0);return result;}void dfs(TreeNode node,int depth){if(node==null){return ;}//我一開始從0相當于先走一步了,所以都是往下遞歸才+1.if(depth>maxDepth){maxDepth = depth;result = node.val;}dfs(node.left,depth+1);dfs(node.right,depth+1);}
}

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

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

相關文章

自建Web網站部署——案例分析

作者主頁: 知孤云出岫 目錄 作者主頁:如何自建一個Web網站一、引言二、需求分析三、技術選型四、開發步驟1. 項目初始化初始化前端初始化后端 2. 前端開發目錄結構示例代碼App.jsHome.js 3. 后端開發目錄結構示例代碼app.jsproductRoutes.jsProduct.js 4. 前后端連接安裝axio…

泛微e-cology WorkflowServiceXml SQL注入漏洞(POC)

漏洞描述&#xff1a; 泛微 e-cology 是泛微公司開發的協同管理應用平臺。泛微 e-cology v10.64.1的/services/接口默認對內網暴露&#xff0c;用于服務調用&#xff0c;未經身份認證的攻擊者可向 /services/WorkflowServiceXml 接口發送惡意的SOAP請求進行SQL注入&#xff0c;…

語音合成新篇章:Transformer模型的革新應用

語音合成新篇章&#xff1a;Transformer模型的革新應用 語音合成技術&#xff0c;又稱文本到語音&#xff08;Text-to-Speech, TTS&#xff09;技術&#xff0c;一直是人工智能領域的重要組成部分。隨著深度學習技術的飛速發展&#xff0c;Transformer模型憑借其卓越的處理序列…

飄雪的冬天,命運的交織

北風呼嘯,天空中飄著鵝毛般的大雪,這又是一個飄雪的冬天。京都醫院潔白的病床上躺著一個年輕女孩,她的臉上沒有一絲血色,眼睛深深地凹了進去,看上去已經病入膏肓。病房的窗口邊,一位身心俱疲的年輕男孩,望著病房外滿天飛舞的雪花,思緒不由回到了三年前的林州市…… 一…

使用JS和CSS制作的小案例(day二)

一、寫在開頭 本項目是從github上摘取&#xff0c;自己練習使用后分享&#xff0c;方便登錄github的小伙伴可以看本篇文章 50項目50天?編輯https://github.com/bradtraversy/50projects50dayshttps://github.com/bradtraversy/50projects50days有興趣的小伙伴可以自己去gith…

面向對象七大原則

學習目標 了解面向對象七大原則基本概念。 在之后實踐應用中&#xff0c;要給予七大原則去設計程序。 為什么有七大原則 七大原則總體要實現的目標是&#xff1a; 高內聚、低耦合。 使程序模塊的可重復性、移植性增強。 高內聚低耦合 從類角度來看&#xff0c;高內聚低…

如何在Linux上部署Ruby on Rails應用程序

在Linux上部署Ruby on Rails應用程序是一個相對復雜的過程&#xff0c;需要按照一系列步驟進行。下面是一個基本的部署過程&#xff0c;涵蓋了從安裝所需軟件到部署應用程序的所有步驟。 安裝必要的軟件 在部署Ruby on Rails應用程序之前&#xff0c;需要確保Linux系統上安裝了…

android 嵌套webview,軟鍵盤遮擋輸入框

實際項目中&#xff0c;android需要加載h5&#xff0c;經常遇到軟鍵盤遮蓋輸入框的情況&#xff0c;h5測試的時候&#xff0c;是沒問題的&#xff0c;但是在APP中是不能把頁面推上去。經測試完美解決了這個問題。 1. oncreate *************************** try {web();layout…

掌握Xcode Storyboard:iOS UI設計的可視化之旅

掌握Xcode Storyboard&#xff1a;iOS UI設計的可視化之旅 在iOS應用程序開發的世界中&#xff0c;用戶界面&#xff08;UI&#xff09;設計是吸引用戶的關鍵。Xcode的Storyboard功能為開發者提供了一個強大的可視化工具&#xff0c;通過拖放的方式快速構建和管理UI。本文將深…

AI網絡爬蟲023:用deepseek批量提取天工AI的智能體數據

文章目錄 一、介紹二、輸入內容三、輸出內容一、介紹 天工AI的智能體首頁: F12查看真實網址和響應數據: 翻頁規律: https://work.tiangong.cn/agents_api/square/sq_list_by_category?category_id=7&offset=0 https://work.tiangong.cn/agents_api/square/sq_list_b…

08 模型演化根本 深度學習推薦算法的五大范式

易經》“九三&#xff1a;君于終日乾乾&#xff1b;夕惕若&#xff0c;厲無咎”。九三是指陽爻在卦中處于第三位&#xff0c;已經到達中位&#xff0c;惕龍指這個階段逐漸理性&#xff0c;德才已經顯現&#xff0c;會引人注目&#xff1b;但要反思自己的不足&#xff0c;努力不…

基于 SSH 的任務調度系統的設計與實現

點擊下載源碼 基于SSH的任務調度系統的設計與實現 摘 要 隨著科學技術的飛速發展和各行各業的分工愈發明細化&#xff0c;對于改革傳統的人工任務調度方式的呼聲越來越大。得益于快速發展的計算機技術&#xff0c;我們看到了改革的方向。本系統是針對企業或者事業單位甚至一個…

Golang | Leetcode Golang題解之第234題回文鏈表

題目&#xff1a; 題解&#xff1a; func reverseList(head *ListNode) *ListNode {var prev, cur *ListNode nil, headfor cur ! nil {nextTmp : cur.Nextcur.Next prevprev curcur nextTmp}return prev }func endOfFirstHalf(head *ListNode) *ListNode {fast : headslo…

camtasia怎么剪掉不用的部分 屏幕錄制的視頻怎么裁剪上下不要的部分 camtasia studio怎么裁剪視頻時長 camtasia怎么剪輯視頻教程

有時我們錄制的屏幕內容&#xff0c;并不一定全部需要。那么&#xff0c;屏幕錄制的視頻怎么裁剪上下不要的部分&#xff1f;可以使用視頻剪輯軟件&#xff0c;或者微課制作工具來進行裁剪。屏幕錄制的視頻怎么旋轉&#xff1f;錄制視頻的旋轉也是一樣的&#xff0c;均在編輯步…

萬字長文之分庫分表里如何優化分頁查詢?【后端面試題 | 中間件 | 數據庫 | MySQL | 分庫分表 | 分頁查詢】

分庫分表的一般做法 一般會使用三種算法&#xff1a; 哈希分庫分表&#xff1a;根據分庫分表鍵算出一個哈希值&#xff0c;根據這個哈希值選擇一個數據庫。最常見的就是數字類型的字段作為分庫分表鍵&#xff0c;然后取余。比如在訂單表里&#xff0c;可以按照買家的ID除以8的…

【Flutter】 webview_flutter避坑

webview_flutter webview_flutter沒有SSL Error接口&#xff0c;也就是說等你的網頁出現SSL 錯誤的時候這個插件無法捕捉處理&#xff0c;除非你改它的源碼。 下面這段是webview_flutter官網的例子&#xff0c;它有onHttpError、onWebResourceError、但沒有任何捕捉 SSL 錯誤…

代謝組數據分析(十五):基于python語言構建PLS-DA算法構建分類模型

介紹 本教程描述了一個具有二元分類結果的研究的典型代謝組學數據分析工作流程。主要步驟包括: 從Excel表格導入代謝物和實驗數據。基于匯總QC的數據清洗。利用主成分分析可視化來檢查數據質量。兩類單變量統計。使用偏最小二乘判別分析(PLS-DA)進行多變量分析,包括: 模型…

go語言 fmt的幾個打印區別以及打印格式

文章目錄 一、打印Print1.1 fmt.Print 和 fmt.Println1.2fmt.Printf1.3 fmt.Sprint, fmt.Sprintf, 和 fmt.Sprintln1.4 fmt.Fprint, fmt.Fprintf, 和 fmt.Fprintln 二、打印格式基本格式動詞整數類型浮點數和復數類型字符串和字節切片布爾類型指針 一、打印Print Go 語言的 fm…

字符串類中的常用方法

1 string對象的創建 靜態創建 String s1  "abc";  String s2  "abc";  動態創建 String s3  new String("abc"); String s4  new String("abc"); 2string對象的不可變性 任何一個String對象在創建之后都不能對它的…

大數據環境下的房地產數據分析與預測研究的設計與實現

1緒論 1.1研究背景及意義 隨著經濟的快速發展和城市化進程的推進&#xff0c;房地產市場成為了國民經濟的重要組成部分。在中國&#xff0c;房地產行業對經濟增長、就業創造和資本投資起到了重要的支撐作用。作為中國西南地區的重要城市&#xff0c;昆明的房地產市場也備受關…