劍指offer之從上到下打印二叉樹

從上到下打印出二叉樹的每個節點,同一層的節點按照從左到右的順序打印。
例如:
給定二叉樹: [3,9,20,null,null,15,7],
在這里插入圖片描述

返回:
[3,9,20,15,7]

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/cong-shang-dao-xia-da-yin-er-cha-shu-lcof
著作權歸領扣網絡所有。商業轉載請聯系官方授權,非商業轉載請注明出處。

解題思路:
這道題明顯是二叉樹的層序遍歷。首先定義一個隊列,將二叉樹的根節點入隊,當隊列非空,訪問隊首元素,然后判斷其左右孩子是否為空,不為空的話,入隊。
代碼:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:vector<int> levelOrder(TreeNode* root) {if(root == NULL) return {};vector<int> ans;queue<TreeNode*> q;q.push(root);while(!q.empty()){TreeNode* temp = q.front();ans.push_back(temp->val);q.pop();if(temp->left != NULL) q.push(temp->left);if(temp->right != NULL) q.push(temp->right);}return ans;}
};

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

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

相關文章

小米真藍牙耳機說明書_小米真無線藍牙耳機Air2 SE評測:僅需169元,享受隨心暢聽體驗...

繼小米真無線藍牙耳機Air 2、小米真無線藍牙耳機Air 2S之后&#xff0c;小米公司又于2020年5月19日再次推出了一款售價更為親民的真無線藍牙耳機新品——小米真無線藍牙耳機Air2 SE&#xff0c;該機不僅延續了小米真無線藍牙耳機Air 2系列的外觀設計&#xff0c;支持開盒彈窗、…

引用與指針的區別

雖然指針和引用都可以完成對其他對象的間接訪問&#xff0c;但是還是有很多不同之處&#xff1a; 1.本身是否是對象 指針本身就是一個對象&#xff0c;而引用本身不是一個對象。因此允許對指針賦值和拷貝&#xff0c;可以定義對指針的引用&#xff0c;已經指向指針的指針&#…

三點外接圓_故地重游偽切圓——偽外接圓的基本性質

在思考一個有關于偽外接圓的等角線問題時&#xff0c;我回想起偽外接圓的一道小題目&#xff0c;這是2012年羅馬尼亞大師杯的第六題&#xff0c;這道題目直接以結論的形式呈現出了偽外接圓的基本性質&#xff0c;是一道入門偽外接圓必做的精巧小題。當然有些讀者可能從未見過&q…

C++的const限定符

const限定符總是讓人很頭疼&#xff0c;下面講解一下幾個比較容易混淆的概念&#xff1a; 對常量的引用&#xff08;常量引用&#xff09;&#xff1a; 一般情況下&#xff0c;引用的類型要與其所引用的對象的類型一致&#xff0c;其中的例外情況就是&#xff0c;當初始化常量…

Linux學習:第五章-Linux用戶和用戶組管理

一用戶管理命令用戶信息文件&#xff1a;/etc/passwd aa:x:501:501::/home/aa:/bin/bash 第一列&#xff1a;用戶名 第二列&#xff1a;密碼標志 第三列&#xff1a;UID用戶ID 0管理員 1-499系統用戶&#xff08;偽用戶&#xff09; 500普通用戶 第四列&#xff1a;GID初始組ID…

一點等于多少厘米_馬桶知識介紹,你了解馬桶多少

我們可能并不了解我們經常運用的馬桶&#xff0c;認為馬桶便是簡簡單單的規劃&#xff0c;沒什么技術含量。其實不然&#xff0c;馬桶的規劃也包含了不少物理學原理。假如你家里的馬桶出現毛病&#xff0c;首先要排查毛病的原因&#xff0c;但是假如不了解馬桶結構圖那就很難把…

動態內存分配與智能指針

內存分配&#xff1a; 靜態存儲區&#xff1a; 局部static對象類的static數據成員定義在任何函數之外的變量 棧區&#xff1a; 函數內的非static對象 動態內存分配的方式有&#xff1a; new和delete智能指針&#xff08;shared_ptr、unique_ptr、weak_ptr&#xff09;all…

1151壓力變送器型號_日本進口橫河EJA530E壓力變送器型號解讀!

橫河EJA變送器對大家來說也許不陌生&#xff0c;但是對于EJA變送器的型號很多人還不是很懂&#xff0c;因為一個全型號代表這很多參數&#xff0c;每一個字母和每一個數字背后都是一個準確的參數&#xff0c;我們在選型的時候要提供必要的參數&#xff0c;更具參數選出合適的型…

plc控制可調節閥流程圖_PLC控制的水箱液位控制系統畢業論文

內容介紹原文檔由會員 莎士比亞 發布論文標準WORD格式排版40頁摘要在人們生活以及工業生產等諸多領域經常涉及到液位和流量的控制問題, 例如居民生活用水的供應, 飲料、食品加工, 溶液過濾, 化工生產等多種行業的生產加工過程, 通常需要使用蓄液池, 蓄液池中的液位需要維持合適…

idea繼承后重新方法快捷鍵_idea 查看類繼承關系的快捷鍵

類似eclipse ctrlt的快捷鍵,idea中是ctrlH…找到對應的類 查看類關系圖…1.在想要查看的類上按 Ctrl H -> Diagrams -> Show Diagrams -> Java Class Diagrams -> Show Implementations -> Ctrl A -> 右擊一下 -> Enter .…打開想要查看的接口或者類文件…

怎樣在數組末尾添加數據_如何利用C++實現可變長的數組?

應該執行什么功能&#xff1f;假設我們要實現一個將自動擴展的數組類&#xff0c;是否需要實現函數&#xff1f;讓我們從下面主要功能使用的功能開始&#xff0c;看看我們需要實現哪些功能。輸出結果&#xff1a;0 1 2 3 40 1 2 100 4您需要做什么才能實現上述功能&#xff1f;…

Linux學習:第六章-Linux服務和進程管理

一進程查看 1psaux查看當前系統所有運行的進程 -a顯示前臺所有進程 -u顯示用戶名 -x顯示后臺進程 user&#xff1a; 用戶名 pid&#xff1a;進程id。PID1init系統啟動的第一個進程 %CPUcpu占用百分比 %MEM內存占用百分比 VSZ虛擬內存占用量KB RSS固定內存占有量 tty登錄終端tty…

覆蓋索引與聯合索引_淺析MySQL的索引覆蓋和索引下推

寫在前面在MySQL數據庫中&#xff0c;索引對查詢的速度有著至關重要的影響&#xff0c;理解索引也是進行數據庫性能調優的起點&#xff0c;索引就是為了提高數據查詢的效率。今天我們來聊聊在MySQL索引優化中兩種常見的方式&#xff0c;索引覆蓋和索引下推索引覆蓋要了解索引覆…

python3 輸入輸出_Python3基礎之輸入和輸出實例分析

通常來說&#xff0c;一個Python程序可以從鍵盤讀取輸入&#xff0c;也可以從文件讀取輸入&#xff1b;而程序的結果可以輸出到屏幕上&#xff0c;也可以保存到文件中便于以后使用。本文就來介紹Python中最基本的I/O函數。一、控制臺I/O1.讀取鍵盤輸入內置函數input([prompt])&…

redis 哨兵 異步_突破Java面試(23-8) - Redis哨兵主備切換的數據丟失問題-阿里云開發者社區...

1 數據丟失的兩個場景主備切換的過程&#xff0c;可能會導致數據丟失1.1 異步復制由于 master > slave的復制是異步的&#xff0c;所以可能有部分數據還沒復制到slave&#xff0c;master就宕機&#xff0c;于是這些數據就丟失了1.2 腦裂導致腦裂&#xff0c;也就是說&#x…

vue 斷開正在發送的請求_vue 發送請求頻繁時取消上一次請求

前言&#xff1a;在項目中經常有一些場景會連續發送多個請求&#xff0c;而異步會導致最后得到展示的結果可能不是最后一次發送請求返回的結果&#xff0c;且對性能也有非常大的影響。場景&#xff1a;列表式切換商品&#xff0c;有時候上一次請求的結果非常慢&#xff0c;而我…

Linux學習:第六章-Linux網絡配置

上一章的補充&#xff1a; 常見網絡端口&#xff1a; 2021ftp服務文件共享 22ssh服務安全遠程網絡管理 23telnet服務 25smtp&#xff1a;簡單郵件傳輸協議發信 110pop3&#xff1a;郵局協議收信 80www網頁服務 3306mysql端口 3389windows終端服務 53DNS端口 /etc/services所有系…

sequelize 增加數據庫字段_Node項目使用Sequelize操作數據庫(一)(包括模型,增,刪、改等)...

Sequelize 是一個基于 Promise 的 Node.js ORM&#xff0c;目前支持 Postgres、MySQL、SQLite 和 Microsoft SQL Server。它具有強大的事務支持&#xff0c;關聯關系、讀取和復制等功能。所謂ORM是指對象關系映射&#xff0c;通過使用描述對象和數據庫之間映射的元數據&#xf…

django orm插入一條_如何通過django的ORM遠程發布文章?

利用django的ORM可以方便的給數據庫插入文章但是假如我django放在阿里云&#xff0c;那我想在本地寫個插件&#xff0c;每天很方便的插入一些數據&#xff0c;最好是通過ORM的&#xff0c;因為管理起來比較方便&#xff0c;會涉及到多個站&#xff0c;可能會有200多個站&#x…

循環斐波那契數列_第五課:斐波那契數列(第一課時)

簡介&#xff1a;又稱黃金分割數列、因數學家列昂納多斐波那契以兔子繁殖為例子而引入&#xff0c;故又稱為“兔子數列”&#xff0c;指的是這樣一個數列&#xff1a;1、1、2、3、5、8、13、21、34……在數學上&#xff0c;斐波那契數列以如下被以遞推的方法定義&#xff1a;F(…