欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java二叉樹(shù)的非遞歸遍歷

 更新時(shí)間:2020年12月04日 18:25:01   作者:隨新飛翔  
二叉樹(shù)的遞歸遍歷比較簡(jiǎn)單,這里就不聊了,今天主要聊聊二叉樹(shù)的非遞歸遍歷,主要借助于“?!焙筮M(jìn)先出的特性來(lái)保存節(jié)點(diǎn)的順序,先序遍歷和中序遍歷相對(duì)來(lái)說(shuō)比較簡(jiǎn)單,重點(diǎn)理解后序遍歷

二叉樹(shù)的遞歸遍歷比較簡(jiǎn)單,這里就不聊了。今天主要聊聊二叉樹(shù)的非遞歸遍歷,主要借助于“?!焙筮M(jìn)先出的特性來(lái)保存節(jié)點(diǎn)的順序,先序遍歷和中序遍歷相對(duì)來(lái)說(shuō)比較簡(jiǎn)單,重點(diǎn)理解后序遍歷。

1. 先看看節(jié)點(diǎn)類(lèi)型:

//二叉樹(shù)的節(jié)點(diǎn)類(lèi)型
private class Node{
	int data; //節(jié)點(diǎn)值
	Node leftChild; //左孩子
	Node rightChild; //右孩子
	public Node(int data) {
		this.data=data;
	}
}

 2.先序遍歷。

非遞歸先序遍歷的思路如下:

1.先將根節(jié)點(diǎn)入棧
2.訪問(wèn)根節(jié)點(diǎn)
3.如果根節(jié)點(diǎn)存在右孩子,則將右孩子入棧
4.如果根節(jié)點(diǎn)存在左孩子,則將左孩子入棧(注意:一定是右孩子先入棧,然后左孩子入棧)
5.重復(fù)2-4

public void preOrder(Node Root) {
	if(Root==null) {
		System.out.println("空樹(shù)");
		return;
	}
	Node tmp=Root;
	Stack<Node> s=new Stack<Node>();
	s.push(tmp); //根節(jié)點(diǎn)入棧
	while(!s.empty()) {
		//1.訪問(wèn)根節(jié)點(diǎn)
		Node p=s.pop();
		System.out.print(p.data+" ");
		//2.如果根節(jié)點(diǎn)存在右孩子,則將右孩子入棧
		if(p.rightChild!=null) {
			s.push(p.rightChild);
		}
		//3.如果根節(jié)點(diǎn)存在左孩子,則將左孩子入棧
		if(p.leftChild!=null) {
			s.push(p.leftChild);
		}
	}
	System.out.println();
}

3.中序遍歷。

非遞歸中序遍歷的思路如下:
1.先將根節(jié)點(diǎn)入棧
2.將當(dāng)前節(jié)點(diǎn)的所有左孩子入棧,直到左孩子為空
3.訪問(wèn)棧頂元素,如果棧頂元素存在右孩子,則繼續(xù)第2步
4.重復(fù)第2、3步,直到棧為空并且所有的節(jié)點(diǎn)都被訪問(wèn)

public void inOrder(Node Root) {
	if(Root==null) {
		System.out.println("空樹(shù)");
		return;
	}
	Node tmp=Root;
	Stack<Node> s=new Stack<Node>();
	while(tmp!=null || !s.empty()) {
		//1.將根節(jié)點(diǎn)入棧
		//2.將所有左孩子入棧
		while(tmp!=null) {
			s.push(tmp);
			tmp=tmp.leftChild;
		}
		//3.訪問(wèn)棧頂元素
		tmp=s.pop();
		System.out.print(tmp.data+" ");
		//4.如果棧頂元素存在右孩子,則將右孩子賦值給tmp,也就是將右孩子入棧
		if(tmp.rightChild!=null) {
			tmp=tmp.rightChild;
		}
		//否則,將tmp置為null,表示下次要訪問(wèn)的是棧頂元素
		else {
			tmp=null;
		}
	}
	System.out.println();
}

4.后序遍歷。

后續(xù)遍歷的非遞歸實(shí)現(xiàn)思路:
1.根節(jié)點(diǎn)入棧
2.將根節(jié)點(diǎn)的左子樹(shù)入棧,直到最左,沒(méi)有左孩子為止
3.得到棧頂元素的值,先不訪問(wèn),判斷棧頂元素是否存在右孩子,如果存在并且沒(méi)有被訪問(wèn),則將右孩子入棧,否則,就訪問(wèn)棧頂元素

	public void postOrder(Node Root) {
		if(Root==null) {
			System.out.println("空樹(shù)");
			return;
		}
		Node tmp=Root; //當(dāng)前節(jié)點(diǎn)
		Node prev=null; //上一次訪問(wèn)的節(jié)點(diǎn)
		Stack<Node> s=new Stack<Node>();
		while(tmp!=null || !s.empty()) {
			//1.將根節(jié)點(diǎn)及其左孩子入棧
			while(tmp!=null) {
				s.push(tmp);
				tmp=tmp.leftChild;
			}
			
			if(!s.empty()) {
				//2.獲取棧頂元素值
				tmp=s.peek();
				//3.沒(méi)有右孩子,或者右孩子已經(jīng)被訪問(wèn)過(guò)
				if(tmp.rightChild==null || tmp.rightChild==prev) {
					//則可以訪問(wèn)棧頂元素
					tmp=s.pop();
					System.out.print(tmp.data+" ");
					//標(biāo)記上一次訪問(wèn)的節(jié)點(diǎn)
					prev=tmp;
					tmp=null;
				}
				//4.存在沒(méi)有被訪問(wèn)的右孩子
				else {
					tmp=tmp.rightChild;
				}
			}
		}
		System.out.println();
	}

利用非遞歸算法來(lái)搜索二叉樹(shù)中的某個(gè)元素java

層序遍歷
可以利用層序遍歷來(lái)解決這個(gè)問(wèn)題

代碼

boolean searchUsingLevelOrder(BinaryTreeNode root,int data){
 BinaryTreeNode temp;
 LLQueue q = new LLQueue();
 if(root == null)
 return false;
 q.enqueue(root);
 while(q.isNotEmpty()){
 temp = q.deQueue();
 if(data == root.getData())
  return true;
 if(temp.getLeft() != null)
  q.enqueue(temp.getLeft());
 if(temp.getRight() != null)
  q.enqueue(temp.getRight());
 }
 q.deleteQueue();
 return false;
}

Java遞歸、非遞歸實(shí)現(xiàn)二叉樹(shù)遍歷

最近找工作做筆試題發(fā)現(xiàn)很重要,就自己寫(xiě)了一點(diǎn),和大家分享

import java.util.Stack;
import java.util.HashMap;

public class BinTree {
	private char date;
	private BinTree lchild;
	private BinTree rchild;

	public BinTree(char c) {
		date = c;
	}

	// 先序遍歷遞歸
	public static void preOrder(BinTree t) {
		if (t == null) {
			return;
		}
		System.out.print(t.date);
		preOrder(t.lchild);
		preOrder(t.rchild);
	}

	// 中序遍歷遞歸
	public static void InOrder(BinTree t) {
		if (t == null) {
			return;
		}
		InOrder(t.lchild);
		System.out.print(t.date);
		InOrder(t.rchild);
	}

	// 后序遍歷遞歸
	public static void PostOrder(BinTree t) {
		if (t == null) {
			return;
		}
		PostOrder(t.lchild);
		PostOrder(t.rchild);
		System.out.print(t.date);
	}

	// 先序遍歷非遞歸
	public static void preOrder2(BinTree t) {
		Stack<BinTree> s = new Stack<BinTree>();
		while (t != null || !s.empty()) {
			while (t != null) {
				System.out.print(t.date);
				s.push(t);
				t = t.lchild;
			}
			if (!s.empty()) {
				t = s.pop();
				t = t.rchild;
			}
		}
	}

	// 中序遍歷非遞歸
	public static void InOrder2(BinTree t) {
		Stack<BinTree> s = new Stack<BinTree>();
		while (t != null || !s.empty()) {
			while (t != null) {
				s.push(t);
				t = t.lchild;
			}
			if (!s.empty()) {
				t = s.pop();
				System.out.print(t.date);
				t = t.rchild;
			}
		}
	}

	// 后序遍歷非遞歸
	public static void PostOrder2(BinTree t) {
		Stack<BinTree> s = new Stack<BinTree>();
		Stack<Integer> s2 = new Stack<Integer>();
		Integer i = new Integer(1);
		while (t != null || !s.empty()) {
			while (t != null) {
				s.push(t);
				s2.push(new Integer(0));
				t = t.lchild;
			}
			while (!s.empty() && s2.peek().equals(i)) {
				s2.pop();
				System.out.print(s.pop().date);
			}

			if (!s.empty()) {
				s2.pop();
				s2.push(new Integer(1));
				t = s.peek();
				t = t.rchild;
			}
		}
	}

	public static void main(String[] args) {
		BinTree b1 = new BinTree('a');
		BinTree b2 = new BinTree('b');
		BinTree b3 = new BinTree('c');
		BinTree b4 = new BinTree('d');
		BinTree b5 = new BinTree('e');

		/**
		 *   a 
		 *   / /
		 *  b  c
		 *  / /
		 * d  e
		 */
		b1.lchild = b2;
		b1.rchild = b3;
		b2.lchild = b4;
		b2.rchild = b5;

		BinTree.preOrder(b1);
		System.out.println();
		BinTree.preOrder2(b1);
		System.out.println();
		BinTree.InOrder(b1);
		System.out.println();
		BinTree.InOrder2(b1);
		System.out.println();
		BinTree.PostOrder(b1);
		System.out.println();
		BinTree.PostOrder2(b1);
	}
}

到此這篇關(guān)于java二叉樹(shù)的非遞歸遍歷的文章就介紹到這了,更多相關(guān)java二叉樹(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java通過(guò)IO流輸出文件目錄的實(shí)例代碼

    Java通過(guò)IO流輸出文件目錄的實(shí)例代碼

    這篇文章主要介紹了Java通過(guò)IO流輸出文件目錄,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • java為何不能多繼承的原因詳解

    java為何不能多繼承的原因詳解

    多重繼承是一個(gè)子類(lèi)從多個(gè)父類(lèi)中繼承屬性和方法。C++, Common Lisp是時(shí)下支持多重繼承的流行語(yǔ)言。那java為何不能多繼承呢,下面小編帶大家來(lái)一起學(xué)習(xí)一下吧
    2019-06-06
  • 揭秘SpringBoot!一分鐘教你實(shí)現(xiàn)配置的動(dòng)態(tài)神刷新

    揭秘SpringBoot!一分鐘教你實(shí)現(xiàn)配置的動(dòng)態(tài)神刷新

    在今天的指南中,我們將深入探索SpringBoot?動(dòng)態(tài)刷新的強(qiáng)大功能,讓你的應(yīng)用保持最新鮮的狀態(tài),想象一下,無(wú)需重啟,你的應(yīng)用就能實(shí)時(shí)更新配置,是不是很酷?跟我一起,讓我們揭開(kāi)這項(xiàng)技術(shù)如何讓開(kāi)發(fā)變得更加靈活和高效的秘密吧!
    2024-03-03
  • Java如何有效避免SQL注入漏洞的方法總結(jié)

    Java如何有效避免SQL注入漏洞的方法總結(jié)

    SQL注入是比較常見(jiàn)的網(wǎng)絡(luò)攻擊方式之一,它不是利用操作系統(tǒng)的BUG來(lái)實(shí)現(xiàn)攻擊,而是針對(duì)程序員編程時(shí)的疏忽,通過(guò)SQL語(yǔ)句,實(shí)現(xiàn)無(wú)帳號(hào)登錄,甚至篡改數(shù)據(jù)庫(kù),這篇文章主要給大家介紹了關(guān)于Java如何避免SQL注入漏洞的兩種方法,需要的朋友可以參考下
    2022-01-01
  • SpringBoot集成內(nèi)存數(shù)據(jù)庫(kù)H2的實(shí)踐

    SpringBoot集成內(nèi)存數(shù)據(jù)庫(kù)H2的實(shí)踐

    h2是內(nèi)存數(shù)據(jù)庫(kù),查詢(xún)高效,可以在開(kāi)發(fā)初期使用它。本文主要介紹了SpringBoot集成內(nèi)存數(shù)據(jù)庫(kù)H2的實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-09-09
  • MyBatis-Plus 如何實(shí)現(xiàn)連表查詢(xún)的示例代碼

    MyBatis-Plus 如何實(shí)現(xiàn)連表查詢(xún)的示例代碼

    這篇文章主要介紹了MyBatis-Plus 如何實(shí)現(xiàn)連表查詢(xún)的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • SpringBoot設(shè)置首頁(yè)(默認(rèn)頁(yè))跳轉(zhuǎn)功能的實(shí)現(xiàn)方案

    SpringBoot設(shè)置首頁(yè)(默認(rèn)頁(yè))跳轉(zhuǎn)功能的實(shí)現(xiàn)方案

    這篇文章主要介紹了SpringBoot設(shè)置首頁(yè)(默認(rèn)頁(yè))跳轉(zhuǎn)功能,本文通過(guò)兩種方案,給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • 關(guān)于BeanUtils.copyProperties(source, target)的使用

    關(guān)于BeanUtils.copyProperties(source, target)的使用

    這篇文章主要介紹了關(guān)于BeanUtils.copyProperties(source, target)的使用說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java進(jìn)階教程之String類(lèi)

    Java進(jìn)階教程之String類(lèi)

    這篇文章主要介紹了Java進(jìn)階教程之String類(lèi),String類(lèi)對(duì)象是不可變對(duì)象(immutable object),String類(lèi)是唯一一個(gè)不需要new關(guān)鍵字來(lái)創(chuàng)建對(duì)象的類(lèi),需要的朋友可以參考下
    2014-09-09
  • ObjectMapper 如何忽略字段大小寫(xiě)

    ObjectMapper 如何忽略字段大小寫(xiě)

    這篇文章主要介紹了使用ObjectMapper實(shí)現(xiàn)忽略字段大小寫(xiě)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06

最新評(píng)論