leetcode hot100刷題日記——33.二叉樹的層序遍歷

解題+總結二維vector的初始化方法

    • 題目描述
    • 情況1:不確定行數和列數
    • 情況2:已知行數和列數
    • 情況3:已知行數但不知道列數
    • 情況4:已知列數但不知道行數

題目描述

在這里插入圖片描述
在這里插入圖片描述
解答:用隊列
思路都差不多,我覺得對于我自己來說,此題最大的難點在于二維vector的初始化

和之前有行數的初始化不一樣的是:此題不確定行數,也不確定列數

那我們就以此題為例,總結一下二維vector的初始化吧。

情況1:不確定行數和列數

class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {//用隊列啦(先進先出)//每一層節點都進隊列完,再開始一個一個出隊列//出來的隊頭元素繼續看有沒有左右孩子節點,有的話進隊列,沒有的話那就不管了vector<vector<int>>res;if(!root){return res;}queue<TreeNode*>q;q.push(root);while(!q.empty()){int curLevelsize=q.size();//記錄當前層有的節點個數//vector<int>()創建一個空的vector<int>對象。push_back將這個空的vector<int>添加到res的末尾。每次調用該語句時,都會為新的一層創建一個空的vector<int>,用于存放該層的節點值res.push_back(vector<int>());for(int i=0;i<curLevelsize;i++){TreeNode *node=q.front();q.pop();//res.back()獲取res中最后一個vector<int>(即當前層的存儲容器)。push_back(node->val)將當前節點的值添加到該vector<int>的末尾。res.back().push_back(node->val);if(node->left){q.push(node->left);}if(node->right){q.push(node->right);}}}return res;}
};

定義:vector<vector>res;
初始化新的行并且先插進vector中:res.push_back(vector());
在新的行中一個一個添加數:res.back().push_back(node->val);

vector<vector<int>> levelOrder(TreeNode* root) {vector<vector<int>> res;if (!root) return res;queue<TreeNode*> q;q.push(root);while (!q.empty()) {int curLevelSize = q.size();res.emplace_back(); // 直接在res末尾構造一個空的vector<int>for (int i = 0; i < curLevelSize; i++) {TreeNode* node = q.front();q.pop();res.back().push_back(node->val); // 添加到最后一層的vector中if (node->left) q.push(node->left);if (node->right) q.push(node->right);}}return res;
}

定義:vector<vector> res;
初始化新的行并且先插進vector中:res.emplace_back();
再在新的行中一個一個添加數:res.back().push_back(node->val);
(此法效率比上一個高些)

vector<vector<int>> levelOrder(TreeNode* root) {vector<vector<int>> res;if (!root) return res;queue<TreeNode*> q;q.push(root);while (!q.empty()) {int curLevelSize = q.size();vector<int> level(curLevelSize); // 預留當前層的空間大小for (int i = 0; i < curLevelSize; i++) {TreeNode* node = q.front();q.pop();level[i] = node->val; // 直接賦值if (node->left) q.push(node->left);if (node->right) q.push(node->right);}res.push_back(level); // 將當前層的vector整體添加到res中}return res;
}

定義:vector<vector> res;
先單獨初始化行:vector level(curLevelSize);
再把整行插入vector:res.push_back(level);
(個人感覺此方法最好記)

情況2:已知行數和列數

int rows = 3;
int cols = 4;
vector<vector<int>> res(rows, vector<int>(cols));res[i][j] = value;  // 直接為第 i 行第 j 列賦值

情況3:已知行數但不知道列數

int rows = 5;
vector<vector<int>> res(rows);vector<int> temp = {1, 2, 3};
res[i] = temp;  // 將第 i 行設置為新行
res[i].push_back(4);  // 在第 i 行中添加元素4

情況4:已知列數但不知道行數

int cols = 4;
vector<vector<int>> res;vector<int> row(cols);
res.push_back(row);  // 添加一行,每行有cols個默認初始化的元素

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

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

相關文章

微服務面試資料1

在當今快速發展的技術領域&#xff0c;微服務架構已經成為構建復雜系統的重要方式之一。本文將圍繞微服務的核心概念、技術棧、分布式事務處理、微服務拆分與設計&#xff0c;以及敏捷開發實踐等關鍵問題展開深入探討&#xff0c;旨在為準備面試的 Java 開發者提供一份全面的復…

【設計模式-4.8】行為型——中介者模式

說明&#xff1a;本文介紹行為型設計模式之一的中介者模式 定義 中介者模式&#xff08;Mediator Pattern&#xff09;又叫作調節者模式或調停者模式。用一個中介對象封裝一系列對象交互&#xff0c;中介者使各對象不需要顯式地互相作用&#xff0c;從而使其耦合松散&#xf…

Oracle 的 SEC_CASE_SENSITIVE_LOGON 參數

Oracle 的SEC_CASE_SENSITIVE_LOGON 參數 關鍵版本信息 SEC_CASE_SENSITIVE_LOGON 參數在以下版本中被棄用&#xff1a; Oracle 12c Release 1 (12.1)&#xff1a; 該參數首次被標記為"過時"(obsolete)但依然保持功能有效 Oracle 18c/19c 及更高版本&#xff1a; …

《圖解技術體系》How Redis Architecture Evolves?

Redis架構的演進經歷了多個關鍵階段&#xff0c;從最初的內存數據庫發展為支持分布式、多模型和持久化的高性能系統。以下為具體演進路徑&#xff1a; 單線程模型與基礎數據結構 Redis最初采用單線程架構&#xff0c;利用高效的I/O多路復用&#xff08;如epoll&#xff09;處…

【電賽培訓課】測量與信號類賽題分析

一、賽題基本情況及硬件電路準備 &#xff08;一&#xff09;賽題基本情況 1.測量與信號類賽題統計 2.測量與信號類賽題特點 &#xff08;二&#xff09;硬件電路準備 綜測環節不允許帶入電腦和手機&#xff0c;需要自己根據題目要求和芯片參數指標進行設計和計算&#xff0c…

移動AI神器GPT Mobile:多模型自由切換

GPT Mobile是什么 GPT Mobile是一款開源的本地移動部署AI工具,主要用于安卓設備。以下是其相關介紹: 功能特點 多模型交互:支持與多個大型語言模型(LLM)同時進行對話,用戶導入相應的API密鑰,就可連接OpenAI、Anthropic、Google、Ollama等平臺,還能根據需求自由切換不同…

AirSim/Cosys-AirSim 游戲開發(二)使用自定義場景

在實際的開發過程中很少會只用 AirSim 自帶的 Blocks 場景&#xff0c;通常需要用到自定義的一些環境和模型&#xff0c;依托于強大的 UE 引擎可以較為逼真地完成場景渲染。這篇博客記錄了如何從頭開始導入一個自定義場景并加載 AirSim 插件。 【Note】&#xff1a;由于 UE Ed…

GPU 圖形計算綜述 (三):可編程管線 (Programmable Pipeline)

2000年左右&#xff0c;微軟在DirectX 8.0中首次提出了Shader Model 1.0和頂點著色器&#xff08;Vertex Shader&#xff09;的概念&#xff0c;標志著可編程管線時代的來臨。隨后&#xff0c;在DirectX 9.0中推出了Shader Model 2.0和像素著色器&#xff08;Pixel Shader&…

【Go語言基礎【3】】變量、常量、值類型與引用類型

文章目錄 一、值&#xff08;Value&#xff09;與字面量&#xff08;Literal&#xff09;1. 值2. 字面量 二、變量&#xff08;Variable&#xff09;1. 聲明方式2. 賦值方式3. 變量默認值4. 類型與值的匹配 三、常量&#xff08;Constant&#xff09;1. 聲明方式2. 常量的特性3…

AWS 亞馬遜 S3存儲桶直傳 前端demo 復制即可使用

自己踩過坑不想別人也踩坑了 亞馬遜S3存儲桶直傳前端demo復制即可使用 <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0…

Python數據可視化科技圖表繪制系列教程(四)

目錄 帶基線的棒棒糖圖1 帶基線的棒棒糖圖2 帶標記的棒棒糖圖 啞鈴圖1 啞鈴圖2 包點圖1 包點圖2 雷達圖1 雷達圖2 交互式雷達圖 【聲明】&#xff1a;未經版權人書面許可&#xff0c;任何單位或個人不得以任何形式復制、發行、出租、改編、匯編、傳播、展示或利用本博…

如何有效刪除 iPhone 上的所有內容?

“在出售我的 iPhone 之前&#xff0c;我該如何清除它&#xff1f;我擔心如果我賣掉它&#xff0c;有人可能會從我的 iPhone 中恢復我的信息。” 升級到新 iPhone 后&#xff0c;你如何處理舊 iPhone&#xff1f;你打算出售、以舊換新還是捐贈&#xff1f;無論你選擇哪一款&am…

[yolov11改進系列]基于yolov11使用SwinTransformer替換backbone用于提高多尺度特征提取能力的python源碼+訓練源碼

【SwinTransformer介紹】 摘要 ViT的缺點&#xff1a; Transformer在語言處理中的基本元素是word token&#xff0c;其特點是語義信息比較密集。而ViT中token的尺度&#xff08;scale&#xff09;是固定的&#xff0c;且視覺token攜帶的語義信息比語言文字序列差&#xff0c…

NoSQL 之 Redis 配置與優化

目錄 一、Redis 介紹 1、關系型數據庫與非關系型數據庫 &#xff08;1&#xff09;關系型數據庫 &#xff08;2&#xff09;非關系型數據庫 &#xff08;3&#xff09;非關系型數據庫產生背景 2、Redis 基礎 &#xff08;1&#xff09;Redis 簡介 &#xff08;2&#x…

算法復雜度,咕咕咕

1.數據結構與算法 數據結構是計算機存儲&#xff0c;組織數據的方式&#xff0c;指相互之間存在一種或多種特定關系的數據元素的集合。可以理解為形狀不同的容器。 算法是定義好的計算過程&#xff0c;取輸入值&#xff0c;經過一系列計算方法變成輸出值。 &#xff08;推薦…

【Linux】 Linux 進程控制

參考博客&#xff1a;https://blog.csdn.net/sjsjnsjnn/article/details/125581083 一、進程創建 1.1 fork()函數 在linux中fork函數是非常重要的函數&#xff0c;它從已存在進程中創建一個新進程。新進程為子進程&#xff0c;而原進程為父進程。進程調用fork&#xff0c;當…

【大模型】MCP是啥?它和點菜、做菜、端菜有啥關系?

什么是 Model Context Protocol (MCP)? Model Context Protocol(模型上下文協議),通俗來說,就是一套用來管理、傳遞和維護對話或交互中上下文信息的規則和格式標準。 換句話說,MCP定義了模型在處理用戶輸入和生成回答時,如何理解、保留和傳遞上下文信息的協議,確保對…

機器學習的數學基礎:決策樹

決策樹 文章目錄 決策樹決策樹的基本思想劃分選擇信息增益增益率基尼指數 減枝處理回歸問題對連續值的處理對缺失值的處理 決策樹的基本思想 決策樹是基于樹結構來進行決策的&#xff0c;通過對問題的判斷與決策&#xff0c;得到最終決策。 一般的&#xff0c;決策樹包括一個…

基于若依前后分離版-用戶密碼錯誤鎖定

sys_config配置參數 user.password.maxRetryCount&#xff1a;最大錯誤次數 user.password.lockTime&#xff1a;鎖定時長 //SysLoginController//登錄 PostMapping("/login") public AjaxResult login(RequestBody LoginBody loginBody) {AjaxResult ajax AjaxR…

Java線程安全集合類

Java線程安全集合類全面解析 目錄 并發集合概述List線程安全實現Set線程安全實現Map線程安全實現Queue線程安全實現總結 并發集合概述 Java提供了多種線程安全的集合類&#xff0c;主要分為兩大類&#xff1a; 傳統同步集合&#xff1a;通過synchronized關鍵字實現線程安全…