Java二叉樹的四種遍歷(遞歸與非遞歸)
一、先序遍歷與后序遍歷
先序遍歷根節(jié)點,再遍歷左子樹,再遍歷右子樹。
后序遍歷先遍歷左子樹,再遍歷右子樹,再遍歷根節(jié)點。
先序遍歷遞歸實現(xiàn):
public static void preOrderByRecursion(TreeNode root) {
// 打印節(jié)點值
System.out.println(root.value);
preOrder(root.left);
preOrder(root.right);
}
先序遍歷的非遞歸實現(xiàn):
非遞歸實現(xiàn)需要借助棧這樣一個數(shù)據(jù)結(jié)構(gòu),實際上遞歸實現(xiàn)也是依靠棧,只不過是隱式的。
- 先將根節(jié)點壓入棧中。
- 彈出棧中的節(jié)點,將彈出節(jié)點的右子節(jié)點壓入棧中,再將彈出節(jié)點的左子樹壓入棧中。
- 重復(fù)步驟2,直到棧為空。
public static void preOrder(TreeNode root) {
if (root == null) {
return;
}
Stack<TreeNode> stack = new Stack<>();
stack.push(root);
while (!stack.empty()) {
TreeNode node = stack.pop();
// 打印節(jié)點值
System.out.print(node.value + " ");
if (node.right != null) {
stack.push(node.right);
}
if (node.left != null) {
stack.push(node.left);
}
}
}
后序遍歷遞歸實現(xiàn):先序遍歷反過來,就不贅述了。
public static void postOrderByRecursion(TreeNode root) {
postOrderByRecursion(root.left);
postOrderByRecursion(root.right);
System.out.println(root.value);
}
后序遍歷非遞歸實現(xiàn):后序遍歷就是先序遍歷反過來,所以需要兩個棧,多出來的棧用來反向輸出。
public static void postOrder(TreeNode root) {
if (root == null) {
return;
}
Stack<TreeNode> s1 = new Stack<>();
Stack<TreeNode> s2 = new Stack<>();
s1.push(root);
while (!s1.empty()) {
TreeNode node = s1.pop();
s2.push(node);
if (node.left != null) {
s1.push(node.left);
}
if (node.right != null) {
s1.push(node.right);
}
}
while (!s2.empty()) {
System.out.println(s2.pop().value);
}
}
二、中序遍歷
中序遍歷先遍歷左子樹,再遍歷根節(jié)點,再遍歷右子樹。
遞歸遍歷:
public static void inOrderByRecursion(TreeNode root) {
if (root == null) {
return;
}
inOrderByRecursion(root.left);
// 打印節(jié)點值
System.out.println(root.value);
inOrderByRecursion(root.right);
}
非遞歸遍歷:
- 將二叉樹的左側(cè)“邊”從上到下依次壓入棧中。
- 從棧中彈出節(jié)點
- 對以彈出節(jié)點的右子節(jié)點為根節(jié)點的子樹,重復(fù)步驟1。
- 重復(fù)2、3步驟,直到棧為空。
public static void inOrder(TreeNode root) {
if (root == null) {
return;
}
Stack<TreeNode> stack = new Stack<>();
TreeNode cur = root;
while (cur != null) {
stack.push(cur);
cur = cur.left;
}
while (!stack.empty()) {
TreeNode node = stack.pop();
System.out.println(node.value);
cur = node.right;
while (cur != null) {
stack.push(cur);
cur = cur.left;
}
}
}
三、層序遍歷
層序遍歷顧名思義就是一層一層,從左到右的遍歷二叉樹。需要用到隊列這一數(shù)據(jù)結(jié)構(gòu)。
- 將根節(jié)點推入隊列。
- 從隊列中取出一個節(jié)點。
- 先將取出節(jié)點的左子節(jié)點推入隊列,再將取出節(jié)點的右子節(jié)點推入隊列。
- 重復(fù)2、3步驟直到隊列中無節(jié)點可取。
public static void floorOrder(TreeNode root) {
if (root == null) {
return;
}
Queue<TreeNode> queue = new LinkedList<>();
queue.add(root);
while (!queue.isEmpty()) {
TreeNode node = queue.poll();
System.out.println(node.value);
if (node.left != null) {
queue.add(node.left);
}
if (node.right != null) {
queue.add(node.right);
}
}
}
到此這篇關(guān)于Java二叉樹的四種遍歷(遞歸與非遞歸)的文章就介紹到這了,更多相關(guān)Java二叉樹的四種遍歷內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Netty源碼分析NioEventLoop處理IO事件相關(guān)邏輯
這篇文章主要介紹了Netty源碼分析NioEventLoop處理IO事件相關(guān)邏輯,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-03-03
java實現(xiàn)String類型和Date類型相互轉(zhuǎn)換
很多人表示,java將string類型轉(zhuǎn)為date類型不知道應(yīng)該怎樣做,本文就來介紹一下java實現(xiàn)String類型和Date類型相互轉(zhuǎn)換,具有一定的參考價值,感興趣的可以了解一下2023-10-10
java 實現(xiàn)字節(jié)流和字節(jié)緩沖流讀寫文件時間對比
這篇文章主要介紹了java 實現(xiàn)字節(jié)流和字節(jié)緩沖流讀寫文件時間對比,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
EasyExcel自定義下拉注解的三種實現(xiàn)方式總結(jié)
使用EasyExcel設(shè)置下拉數(shù)據(jù)時,每次都要創(chuàng)建一個SheetWriteHandler組件確實比較繁瑣,為了優(yōu)化這個過程,我們可以通過自定義注解來簡化操作,下面就來看看具體實現(xiàn)方法吧2024-10-10

