代碼隨想錄算法訓練營第36期DAY22

DAY22

654最大二叉樹

自己做的時候忽略了:nums.length>=1的題給條件。所以每次遞歸都要判斷是否size()>=1,不要空的。

  1. /**
  2. ?*?Definition?for?a?binary?tree?node.
  3. ?*?struct?TreeNode?{
  4. ?*?????int?val;
  5. ?*?????TreeNode?*left;
  6. ?*?????TreeNode?*right;
  7. ?*?????TreeNode()?:?val(0),?left(nullptr),?right(nullptr)?{}
  8. ?*?????TreeNode(int?x)?:?val(x),?left(nullptr),?right(nullptr)?{}
  9. ?*?????TreeNode(int?x,?TreeNode?*left,?TreeNode?*right)?:?val(x),?left(left),?right(right)?{}
  10. ?*?};
  11. ?*/
  12. class?Solution?{
  13. public:
  14. ????TreeNode*?constructMaximumBinaryTree(vector<int>&?nums)?{
  15. ????????TreeNode*?node=new?TreeNode(0);
  16. ????????if(nums.size()==1)?{
  17. ????????????node->val=nums[0];
  18. ????????????return?node;
  19. ????????}
  20. ????????int?index=0;
  21. ????????for(int?i=1;i<nums.size();i++)
  22. ????????{
  23. ????????????if(nums[index]<nums[i])?index=i;
  24. ????????}
  25. ????????node->val=nums[index];
  26. ????????if(index>0){
  27. ????????????vector<int>?ln(nums.begin(),nums.begin()+index);
  28. ????????????node->left=constructMaximumBinaryTree(ln);
  29. ????????}
  30. ????????if(index<nums.size()-1){
  31. ????????????vector<int>?rn(nums.begin()+index+1,nums.end());
  32. ????????????node->right=constructMaximumBinaryTree(rn);
  33. ????????}
  34. ????????return?node;
  35. ????}
  36. };

617合并二叉樹

遞歸之前,先弄明白遍歷順序很重要:

  1. /**
  2. ?*?Definition?for?a?binary?tree?node.
  3. ?*?struct?TreeNode?{
  4. ?*?????int?val;
  5. ?*?????TreeNode?*left;
  6. ?*?????TreeNode?*right;
  7. ?*?????TreeNode()?:?val(0),?left(nullptr),?right(nullptr)?{}
  8. ?*?????TreeNode(int?x)?:?val(x),?left(nullptr),?right(nullptr)?{}
  9. ?*?????TreeNode(int?x,?TreeNode?*left,?TreeNode?*right)?:?val(x),?left(left),?right(right)?{}
  10. ?*?};
  11. ?*/
  12. class?Solution?{
  13. public:
  14. ????TreeNode*?mergeTrees(TreeNode*?root1,?TreeNode*?root2)?{
  15. ????????if(root1==nullptr)?return?root2;
  16. ????????if(root2==nullptr)?return?root1;
  17. ????????root1->val+=root2->val;
  18. ????????root1->left=mergeTrees(root1->left,root2->left);
  19. ????????root1->right=mergeTrees(root1->right,root2->right);
  20. ????????return?root1;
  21. ????}
  22. };

700二叉搜索樹中的搜索

先寫迭代法,返璞歸真咯:

  1. /**
  2. ?*?Definition?for?a?binary?tree?node.
  3. ?*?struct?TreeNode?{
  4. ?*?????int?val;
  5. ?*?????TreeNode?*left;
  6. ?*?????TreeNode?*right;
  7. ?*?????TreeNode()?:?val(0),?left(nullptr),?right(nullptr)?{}
  8. ?*?????TreeNode(int?x)?:?val(x),?left(nullptr),?right(nullptr)?{}
  9. ?*?????TreeNode(int?x,?TreeNode?*left,?TreeNode?*right)?:?val(x),?left(left),?right(right)?{}
  10. ?*?};
  11. ?*/
  12. class?Solution?{
  13. public:
  14. ????TreeNode*?searchBST(TreeNode*?root,?int?val)?{
  15. ????????while(root!=nullptr)
  16. ????????{
  17. ????????????if(root->val<val)?root=root->right;
  18. ????????????else?if(root->val>val)?root=root->left;
  19. ????????????else?return?root;
  20. ????????}
  21. ????????return?nullptr;
  22. ????}
  23. };

遞歸試試:

遞歸還是寫不出來,早上看過答案也寫不出來,邏輯理不清,什么時候該創建變量去接住遞歸的結果?

  1. /**
  2. ?*?Definition?for?a?binary?tree?node.
  3. ?*?struct?TreeNode?{
  4. ?*?????int?val;
  5. ?*?????TreeNode?*left;
  6. ?*?????TreeNode?*right;
  7. ?*?????TreeNode()?:?val(0),?left(nullptr),?right(nullptr)?{}
  8. ?*?????TreeNode(int?x)?:?val(x),?left(nullptr),?right(nullptr)?{}
  9. ?*?????TreeNode(int?x,?TreeNode?*left,?TreeNode?*right)?:?val(x),?left(left),?right(right)?{}
  10. ?*?};
  11. ?*/
  12. class?Solution?{
  13. public:
  14. ????TreeNode*?searchBST(TreeNode*?root,?int?val)?{
  15. ????????if(root==nullptr||root->val==val)?return?root;
  16. ????????TreeNode*?result=nullptr;
  17. ????????if(root->val<val)?{
  18. ????????????result=searchBST(root->right,val);
  19. ????????}
  20. ????????if(root->val>val){
  21. ????????????result=searchBST(root->left,val);
  22. ????????}
  23. ????????return?result;
  24. ????}
  25. };

遞歸沒接住(沒找到),就返回的是初始化的result=nullptr;

98驗證二叉搜索樹

有很多陷阱在里面。迭代法就很容易出錯。

這里要知道并利用這個性質:二叉搜索樹的中序遍歷序列是嚴格單調增的數組。

  1. /**
  2. ?*?Definition?for?a?binary?tree?node.
  3. ?*?struct?TreeNode?{
  4. ?*?????int?val;
  5. ?*?????TreeNode?*left;
  6. ?*?????TreeNode?*right;
  7. ?*?????TreeNode()?:?val(0),?left(nullptr),?right(nullptr)?{}
  8. ?*?????TreeNode(int?x)?:?val(x),?left(nullptr),?right(nullptr)?{}
  9. ?*?????TreeNode(int?x,?TreeNode?*left,?TreeNode?*right)?:?val(x),?left(left),?right(right)?{}
  10. ?*?};
  11. ?*/
  12. class?Solution?{
  13. private:
  14. ????vector<int>?result;
  15. ????void?exc(TreeNode?*root)
  16. ????{
  17. ????????if(root==nullptr)?return;
  18. ????????exc(root->left);
  19. ????????result.push_back(root->val);
  20. ????????exc(root->right);
  21. ????}
  22. public:
  23. ????bool?isValidBST(TreeNode*?root)?{
  24. ????????result.clear();
  25. ????????exc(root);
  26. ????????for(int?i=1;i<result.size();i++)
  27. ????????{
  28. ????????????if(result[i-1]>=result[i])?return?false;
  29. ????????}
  30. ????????return?true;
  31. ????}
  32. };

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

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

相關文章

牛客網刷題 | BC84 牛牛學數列2

目前主要分為三個專欄&#xff0c;后續還會添加&#xff1a; 專欄如下&#xff1a; C語言刷題解析 C語言系列文章 我的成長經歷 感謝閱讀&#xff01; 初來乍到&#xff0c;如有錯誤請指出&#xff0c;感謝&#xff01; 描述 這次牛牛又換了個數…

sql中的exists和in的區別

在SQL中&#xff0c;EXISTS 和 IN 都用于子查詢&#xff0c;但它們的用法和目的有所不同。 ### EXISTS EXISTS 是一個邏輯運算符&#xff0c;用于檢查子查詢是否返回任何行。如果子查詢返回至少一行&#xff0c;那么 EXISTS 子句的結果為 TRUE&#xff1b;否則&#xff0c;結果…

一個用Kotlin編寫簡易的串行任務調度器

引言 由于項目中有處理大量后臺任務并且串行執行的需求&#xff0c;特意寫了一個簡易的任務調度器&#xff0c;方便監控每個任務執行和異常情況&#xff0c;任務之間互不影響。正如上所述&#xff0c;Kotlin中的TaskScheduler類提供了一個強大的解決方案&#xff0c;用于使用S…

「AIGC」Python實現tokens算法

本文主要介紹通過python實現tokens統計,避免重復調用openai等官方api,開源節流。 一、設計思路 初始化tokenizer使用tokenizer將文本轉換為tokens計算token的數量二、業務場景 2.1 首次加載依賴 2.2 執行業務邏輯 三、核心代碼 from transformers import AutoTokenizer imp…

React: memo

React.memo 允許你的組件在 props 沒有改變的情況下跳過重新渲染。 const MemoizedComponent memo(SomeComponent, arePropsEqual?)React 通常在其父組件重新渲染時重新渲染一個組件。你可以使用 memo 創建一個組件&#xff0c;當它的父組件重新渲染時&#xff0c;只要它的新…

centos7服務器采用局域網內筆記本代理上網

一、背景 某臺服務器操作系統是centos 7&#xff0c;不能上網。我想在上面裝個ftp軟件&#xff1a;vsftpd。 二、思路 要安裝這個軟件&#xff0c;有2種方案 1&#xff09;設置該臺centos7可以上網 2&#xff09;離線安裝vsftpd 鑒于各種依賴&#xff0c;萬一因為依賴不全或…

《海峽科技與產業》是什么級別的期刊?是正規期刊嗎?能評職稱嗎?

問題解答 問&#xff1a;《海峽科技與產業》期刊是什么級別&#xff1f; 答&#xff1a;國家級 主管單位&#xff1a;中華人民共和國科學技術部 主辦單位&#xff1a;科技部海峽兩岸科學技術交流中心 問&#xff1a;《海峽科技與產業》影響因子&#xff1f; 答&#xff1a;…

相位;傅里葉變換和傅里葉級數是什么;歐拉公式是什么,和傅里葉關系;

目錄 相位 傅里葉變換公式使用舉例 實際案例 傅里葉變換和傅里葉級數是什么

隨筆:棋友們

我是在小學二年級學會中國象棋的&#xff0c;準確說&#xff0c;是學會象棋的下棋規則的&#xff0c;師傅是二舅。我最早的對手就是同學波仔。波仔比我略早學會象棋&#xff0c;總用連珠炮欺負我&#xff0c;開局幾步棋就把我將死。我不知道怎么破解。輪到我先走時&#xff0c;…

扭虧為盈的賽力斯,真正進入穩態了嗎?

“72小時內大定破1萬臺”。5月15日&#xff0c;問界新M5開啟全國大規模交付&#xff0c;從當前取得的成績來看&#xff0c;賽力斯的“富貴”似乎還將延續。 其實&#xff0c;此前基于問界新M7等車型的爆火&#xff0c;賽力斯已經找到了創收軌道。財報顯示&#xff0c;2024年一…

alist網盤自動同步

alist網盤自動同步 alist可以設置目錄定時轉存到各個網盤&#xff0c;做到夸網盤&#xff0c;多備份的效果可以將自己掛載的alist 下的各個目錄相互間進行同步&#xff0c;原理是采用alist原始api調用執行同步原理1.匹配文件名稱是否相同,2.文件大小是否相同&#xff0c;相同會…

一文詳細解析Google編碼規范工具cpplint的下載安裝與使用

目錄 一、什么是cpplint 二、cpplint能實現的功能 三、cpplint的下載與使用 1、配置python環境 2、安裝cpplint 四、cpplint常用命令講解 1、常用命令查看 2、常用命令詳解 3、命令使用方式 五、 cpplint的實用技巧 1、集成cpplint 1.1、修改調用接口. 1.2、直接把…

數據結構(C):樹的概念和二叉樹初見

目錄 &#x1f37a;0.前言 1.樹概念及結構 2.認識一棵樹 3.樹的表示 3.1樹在實際中的運用&#xff08;表示文件系統的目錄樹結構&#xff09; 4.二叉樹 4.1特殊的二叉樹 4.2二叉樹的性質 &#x1f48e;5.結束語 &#x1f37a;0.前言 言C之言&#xff0c;聊C之識&…

卷積模型的剪枝、蒸餾---蒸餾篇--NST特征蒸餾(以deeplabv3+為例)

本文使用NST特征蒸餾實現deeplabv3+模型對剪枝后模型的蒸餾過程; 一、NST特征蒸餾簡介 下面是兩張疊加了熱力圖(heat map)的圖片,從圖中很容易看出這兩個神經元具有很強的選擇性:左圖的神經元對猴子的臉部非常敏感,右側的神經元對字符非常敏感。這種激活實際上意味著神經…

程序員績效管理-序言

開辟一個新專欄專門討論程序員績效管理。作為軟件開發企業&#xff0c;公司的命脈掌握在程序員手中。程序員的績效管理是個超級難題。小張和老王專欄介紹了兩個典型的人員。但是這是兩個虛擬的極端人員&#xff0c;大部分開發人員沒有那么容易分辨。1個任務&#xff0c;應該1天…

LabVIEW軟件開發工程師需要具備哪些能力與素質?

成為一名優秀的LabVIEW軟件開發工程師&#xff0c;需要具備以下能力與素質&#xff1a; 技術能力 LabVIEW編程技能&#xff1a; 精通LabVIEW編程&#xff0c;能夠熟練使用其圖形化編程界面。熟悉LabVIEW中的各種功能模塊和工具包&#xff0c;如數據采集&#xff08;DAQ&#x…

如何配置Nacos的健康檢查參數?

在微服務架構中&#xff0c;服務注冊與發現以及健康檢查是至關重要的組件。Nacos&#xff0c;作為阿里巴巴開源的一個更易于構建云原生應用的動態服務發現、配置和服務管理平臺&#xff0c;廣泛應用于微服務架構中。在Nacos中&#xff0c;服務的健康檢查是一個核心功能&#xf…

【Python】使用MySQL綜合案例

數據說明: 一月份各省銷售數據&#xff1a;csv格式 二月份各省銷售數據&#xff1a;json格式 實現要求&#xff1a;將兩個文件中的數據存儲到數據庫中&#xff0c;并反向從數據庫中讀取數據存儲為json格式文件 本文提供數據 完成案例所需基礎 【Python】基礎知識(函數與數…

C++ 日志庫 log4cpp 編譯、壓測及其范例代碼 [全流程手工實踐]

文章目錄 一、 log4cpp官網二、下載三、編譯1.目錄結構如下2.configure 編譯3.cmake 編譯 四、測試五、壓測源碼及結果1.運行環境信息2.壓測源碼3.壓測結果 文章內容&#xff1a;包含了對其linux上的完整使用流程&#xff0c;下載、編譯、安裝、測試用例嘗試、以及一份自己寫好…

Qt | QTimer 類(計時器)

01、相關知識回顧 Qt C++ | QTimer經驗總結Qt | QDateTimeEdit、QDateEdit類和QTimeEdit類02、QTimer 類 1、QTimer 類是 QObejct 的直接子類,該類用于實現計時器,QTimer 類未繼承自 QW