二叉樹的蛇形遍歷 leetcode 103

給定一個二叉樹,返回其節點值的鋸齒形層次遍歷。(即先從左往右,再從右往左進行下一層遍歷,以此類推,層與層之間交替進行)。

例如:
給定二叉樹?[3,9,20,null,null,15,7],

    3/ \9  20/  \15   7

返回鋸齒形層次遍歷如下:

[[3],[20,9],[15,7]
]

首先我們想一下二叉樹的層序遍歷的思想:

層序遍歷的主要思路就是先把根節點存入,然后輸出,輸出的同時把根節點的左右孩子存入,再把左孩子輸出,同樣輸出的同時把左孩子的孩子在存入,直到遍歷完成,例如:

? ? ? a

? b ????? c

d ? e ? f ? g? ?

先把a存入,然后輸出a,輸出a的同時把b c存入,然后再輸出b,輸出b的同時存入d e,繼續輸出c,然后存入f g,直到全部輸出

//層序遍歷
vector<int> levelOrder(TreeNode *root) {vector<int> answer;queue<TreeNode *>p;if (root == nullptr) return answer;p.push(root);TreeNode* h = nullptr;while (!p.empty()) {int size = p.size();while (size--) {h = p.front();answer.push_back(h->val);p.pop();//子樹非空,則壓入隊列   if (h->left != NULL)p.push(h->left);if (h->right != NULL)p.push(h->right);}}return answer;}

思路一:對特定輸入的結果進行反轉輸出

因為輸出結果是第二層、第四層、第六層。。。的層序遍歷結果反向輸出,可以在輸出時將對應的行反轉輸出即可。

//蛇形遍歷(反轉)
vector<vector<int>> zigzagLevelOrder(TreeNode* root) {vector<vector<int>> answer;if (root == nullptr) return answer;queue<TreeNode *>p;p.push(root);TreeNode* h = nullptr;while (!p.empty()) {int size = p.size();vector<int> temp;while (size--) {h = p.front();temp.push_back(h->val);p.pop();//子樹非空,則壓入隊列   if (h->left != NULL)p.push(h->left);if (h->right != NULL)p.push(h->right);}answer.push_back(temp);}for (int i = 1; i < answer.size(); i += 2) {reverse(answer[i].begin(), answer[i].end());}return answer;
}


思路二:利用雙端隊列

//蛇形遍歷(雙端隊列)
vector<vector<int>> zigzagLevelOrder(TreeNode* root) {vector<vector<int>> answer;if (root == nullptr) return answer;deque<TreeNode*> deq;deq.push_back(root);int flag = 0;int size = 1;TreeNode *node = nullptr;while (!deq.empty()) {vector<int> vec;size = deq.size();for (int i = 0; i < size; i++) {node = deq.front();deq.pop_front();//從左到右      if (flag % 2 == 0) {vec.push_back(node->val);}else {vec.insert(vec.begin(), node->val);}if (node->left != NULL)deq.push_back(node->left);if (node->right != NULL)deq.push_back(node->right);}answer.push_back(vec);flag++;}return answer;
}


研究了一下雙端隊列,后來發現改成隊列就可以了。

class Solution {
public:vector<vector<int>> zigzagLevelOrder(TreeNode* root) {  vector<vector<int>> answer;  if (root == nullptr) return answer;  queue<TreeNode*> deq;  deq.push(root);  int flag = 0;  int size = 1;  TreeNode *node = nullptr;  while (!deq.empty()) {  vector<int> vec;  size = deq.size();  for (int i = 0; i < size; i++) {  node = deq.front();  deq.pop();  //從左到右        if (flag % 2 == 0) {  vec.push_back(node->val);  }  else {  vec.insert(vec.begin(), node->val);  }  if (node->left != NULL)  deq.push(node->left);  if (node->right != NULL)  deq.push(node->right);  }  answer.push_back(vec);  flag++;  }  return answer;  
}  
};

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

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

相關文章

Teams Tab的Single Sign-On

在我寫這篇文章的時候&#xff0c;這個SSO機制還是在 Developer Preview 階段&#xff0c;可能在發布前還會有一些改進。不過我覺得這個功能很好&#xff0c;所以先和大家分享一下。 如果大家之前已經開發過Teams的tab應用&#xff0c;可能會發現如果你需要一個當前用戶的toke…

vim編輯器的使用--轉自MJ學長

一、引言 1. vim是一款功能強大的文本編輯器&#xff0c;如果使用熟練&#xff0c;將會有效幫助我們提高編輯文本、程序的效率。vim編輯器的上手使用門檻比較高&#xff0c;很多人怯于要記很多命令&#xff0c;往往在學習的初期階段就望而卻步。 2. vim的學習需要不斷的練習、使…

算法引入

算法的概念&#xff1a; 解決問題的思路。 時間復雜度&#xff1a; 定義&#xff1a; 基本運算的執行數量。是算法效率的衡量的量。 計算準則&#xff1a; 基本操作&#xff1a;即只有常數項。復雜度認為1順序&#xff0c;按照加法計算循環&#xff0c;按照乘法計算條件。按照最…

如何開發Teams Bot

很多朋友問我如何開發一個成功的Teams Bot&#xff0c;他們說Bot Framework SDK看起來簡單&#xff0c;但是真要的去開發一款成熟的bot&#xff0c;很多地方還是不知道如何使用。我從最早的bot framework還在beta的時候開始用&#xff0c;后來framework經歷了多次大的改動&…

[CF903G]Yet Another Maxflow Problem

[CF903G]Yet Another Maxflow Problem 題目大意&#xff1a; 有\(A\)類點和\(B\)類點各\(n(n\le2\times10^5)\)個&#xff0c;所有\(A_i\)到\(A_{i1}\)有一條權值為\(a_i\)的有向邊&#xff0c;所有\(B_i\)到\(B_{i1}\)有一條權值為\(b_i\)的有向邊&#xff0c;另有\(m(m\le2\t…

P1579哥德巴赫猜想

寫來自己學習用~ 題目內容&#xff1a; 1742年6月7日哥德巴赫寫信給當時的大數學家歐拉&#xff0c;正式提出了以下的猜想&#xff1a;任何一個大于9的奇數都可以表示成3個質數之和。質數是指除了1和本身之外沒有其他約數的數&#xff0c;如2和11都是質數&#xff0c;而6不是質…

在VSCode Remote環境下開發Teams Bot

我使用VS Code開發已經有蠻長一段時間了&#xff0c;時間長了&#xff0c;越來越喜歡VS Code&#xff0c;雖然有些時候會沒有傳統的VS方便&#xff0c;比如開發Azure Function時你需要編寫一下launch.json&#xff0c;而且你需要手動啟動StorageEmulator&#xff0c;但是也正是…

查看安卓APK源碼破解

原文:查看安卓APK源碼破解工具準備&#xff1a; <1>.android4me的AXMLPrinter2工具 <2>dex2jar <3>jd-gui 工具下載&#xff1a;http://download.csdn.net/detail/catshitone/8491347 開始&#xff1a; 第一步&#xff1a; 首先用解壓軟件&#xff08;如好…

實驗六:類的封裝

一、實驗代碼如下&#xff1a; 1 package 實驗6;2 3 import java.util.Scanner;4 5 6 public class Account {7 8 public int id;9 public String name;10 public long number;11 public long time;12 public int money;13 14 //方法Account()…

Teams Bot開發系列:初識Bot

上次我們講了Teams Bot開發的概述&#xff0c;講了Azure Bot Service&#xff0c;Bot Framework SDK和我們自己的bot服務的概念&#xff0c;這篇文章就帶大家看看Azure Bot Service和我們的bot是如何發生關系的。 我們自己開發的bot服務實際上就是一個api service&#xff0c;…

[環境搭建]SDN網絡感知服務與最短路徑應用

1.安裝python模塊networkxpip install networkx2.給Network_Awareness.py加修改權限chmod 777 Network_Awareness.py3.下載安裝ryugit clone git://github.com/osrg/ryu.gitcd ryu sudo python ./setup.py install#若已安裝ryu,刪了再裝&#xff0c; pip uninstall ryu4.修改“…

我需要別人承認才快樂嗎?

關于生命的感悟兩個故事第一個故事&#xff0c;一個尖子生考上了麻省理工學院&#xff0c;在那里所有同學都很優秀&#xff0c;競爭非常強烈&#xff0c;她發現再也不能出類拔萃&#xff0c;在各方面贏過別人&#xff0c;于是覺得生活看不到希望&#xff0c;郁郁寡歡&#xff0…

Teams Bot開發系列:Activity和Turn

這篇文章我們來說一下Activity和Turn這兩個bot framework中最重要的兩個概念&#xff0c;同時也介紹一下TurnContext和BotAdapter Activity 一個activity是聊天雙方的一個信息載體&#xff0c;它可以是一條消息&#xff0c;也可以是一個動作。比如用戶給bot發送一條文字消息&…

ubuntu16.04下安裝opencv出現libgtk2.0-dev配置失敗問題解決方法

第一次在ubuntu下安裝opencv&#xff0c;遇到很多問題&#xff0c;特別是libgtk2.0-dev總是配置失敗的問題&#xff0c;在網上也看到一些解決方法&#xff0c;自己也遇到一些比較奇葩的問題&#xff0c;故整理于此。 網上大部分的解決方案就是更改下載源&#xff0c;我看到一些…

03|模型I/O:輸入提示、調用模型、解析輸出

03&#xff5c;模型I/O&#xff1a;輸入提示、調用模型、解析輸出 從這節課開始&#xff0c;我們將對 LangChain 中的六大核心組件一一進行詳細的剖析。 模型&#xff0c;位于 LangChain 框架的最底層&#xff0c;它是基于語言模型構建的應用的核心元素&#xff0c;因為所謂 …

selenuim自動化爬取汽車在線谷米愛車網車輛GPS數據爬蟲

#為了實時獲取車輛信息&#xff0c;以及為了后面進行行使軌跡繪圖&#xff0c;寫了一個基于selelnium的爬蟲爬取了車輛gps數據。 #在這里發現selenium可以很好的實現網頁解析和處理js處理 #導包 import timefrom selenium import webdriverfrom selenium.webdriver.support.wai…

Teams Bot開發系列:Activity處理流程

上篇文章介紹了什么是Activity&#xff0c;Turn&#xff0c;TurnContext和BotAdapter&#xff0c;這篇文章我們看看這些東西是如何竄起來的&#xff0c;他們是如何處理用戶發給bot的消息的。 我們以一個最簡單的bot&#xff0c;echo bot為例子&#xff0c;所謂的echo bot就是用…

寫單元測試的好處(轉)

許多開發者都有個習慣&#xff0c;常常不樂意去寫個簡單的單元測試程序來驗證自己的代碼。對自己的程序一直非常有自信&#xff0c;或存在僥幸心理每次運行通過后就直接扔給測試組測試了。然而每次測試組的BUG提交過來后就會發現自己的程序還存在許多沒有想到的漏洞。但是每次修…

linux下搭建go環境--問題記錄

記錄自己在linux上搭建go環境的經歷。&#xff08;因為各種版本&#xff0c;linux系統問題掙扎了幾天&#xff09; 安裝vmware-tools,把我要運行代碼拷進來。這個網上方法很多&#xff0c;我的電腦抽風不能安裝&#xff0c;后面重裝的虛擬機確定Ubuntu版本、位數。很重要&#…

Teams Bot開發系列:Teams的Activity處理

上一篇文章講了activity處理的流程&#xff0c;我們bot的核心處理邏輯放在ActivityHandler的子類里&#xff0c;通過重載OnMessageActivityAsync()方法來實現。 這篇文章我來講一下對于Teams的bot來說&#xff0c;整個處理的邏輯會有哪些不同點。 通過之前的文章&#xff0c;…