本篇文章為大家展示了怎樣進(jìn)行從上到下打印python二叉樹的分析,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
成都創(chuàng)新互聯(lián)公司主要從事成都網(wǎng)站建設(shè)、做網(wǎng)站、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)鹽池,10余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):028-86922220
從上到下按層打印二叉樹,同一層的節(jié)點(diǎn)按從左到右的順序打印,每一層打印到一行。
給定二叉樹: [3,9,20,null,null,15,7],
3
/ \
9 20
/ \
15 7
[
[3],
[9,20],
[15,7]
]
O(N)
O(N)
class Solution:
def levelOrder(self, root: TreeNode) -> List[List[int]]:
res = []
if not root:
return res
q = [root]
while q:
# 當(dāng)前層長(zhǎng)度
curlen = len(q)
curlevel = []
for node in q[:curlen]:
# 將當(dāng)前層的節(jié)點(diǎn)值依次加入結(jié)果中
curlevel.append(node.val)
# 只追加非空子節(jié)點(diǎn)
if node.left:
q.append(node.left)
if node.right:
q.append(node.right)
res.append(curlevel)
# 隊(duì)列切片, 開始處理下一層
q = q[curlen:]
return res
上述內(nèi)容就是怎樣進(jìn)行從上到下打印python二叉樹的分析,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。