摘要:節(jié)點(diǎn)類二叉樹(shù)類實(shí)現(xiàn)了二叉樹(shù)插入刪除查找前序遍歷中序遍歷后序遍歷層序遍歷二叉樹(shù)序列化和反序列化二叉樹(shù)的常見(jiàn)操作增加刪除查找先序中序后序?qū)有虮闅v序列化二叉樹(shù)先序?qū)有蛐蛄谢头葱蛄谢刃蚍葱蛄谢瘜有蛐蛄谢瘜有蚍葱蛄谢瘮?shù)據(jù)測(cè)試建立一棵二叉樹(shù)參考資料
節(jié)點(diǎn)類
public class Node { public Node left; public Node right; public int data; public Node(int data){ this.left = null; this.right = null; this.data = data; } }二叉樹(shù)類
實(shí)現(xiàn)了二叉樹(shù)插入、刪除、查找、前序遍歷、中序遍歷、后序遍歷、層序遍歷、二叉樹(shù)序列化和反序列化
import java.util.LinkedList; import java.util.Queue; import java.util.Stack; public class BinaryTree { public Node root; public BinaryTree() { this.root=null; } /** * 二叉樹(shù)的常見(jiàn)操作 * 增加、刪除、查找 */ public void insert(int data){ Node node=new Node(data); if(this.root==null){ this.root=node; }else{ Node current=this.root; Node parent; while(true){ parent=current; if(data /** * 先序、中序、后序、層序遍歷 */ public void preOrderCur(Node head){ if(head==null){ return; } System.out.println(head.data+" "); preOrder(head.left); preOrder(head.right); } public void preOrder(Node head){ if(head!=null){ Stackstack=new Stack (); stack.add(head); while(!stack.isEmpty()){ head=stack.pop(); System.out.println(head.data+" "); if(head.right!=null){ stack.push(head.right); } if(head.left!=null){ stack.push(head.left); } } } } public void inOrderCur(Node head){ if(head==null){ return ; } preOrder(head.left); System.out.println(head.data+" "); preOrder(head.right); } public void inOrder(Node head){ if(head!=null){ Stack stack=new Stack (); while(!stack.isEmpty()||head!=null){ if(head!=null){ stack.push(head); head=head.left; }else{ head=stack.pop(); System.out.println(head.data+" "); head=head.right; } } } } public void posOrderCur(Node head){ if(head==null){ return; } preOrder(head.left); preOrder(head.right); System.out.println(head.data+" "); } public void posOrder(Node head){ if(head!=null){ Stack stack=new Stack (); stack.push(head); Node c=null; while(!stack.isEmpty()){ c=stack.peek(); if(c.left!=null&&head!=c.left&&head!=c.right){ stack.push(c.left); }else if(c.right!=null &&head!=c.right){ stack.push(c.right); }else{ System.out.println(stack.pop().data+" "); head=c; } } } } public void levelOrder(Node head){ if(head==null){ return; } Queue queue=new LinkedList (); queue.offer(head); while(!queue.isEmpty()){ head=queue.poll(); System.out.println(head.data); if(head.left!=null){ queue.offer(head.left); } if(head.right!=null){ queue.offer(head.right); } } } /** * 序列化二叉樹(shù) * 先序、層序序列化和反序列化 */ public String serialPre(Node head){ if(head==null){ return "#!"; } String str=head.data+"!"; str+=serialPre(head.left); str+=serialPre(head.right); return str; } /*先序反序列化*/ public Node recoByPre(String preStr){ String[] values=preStr.split("!"); Queue數(shù)據(jù)測(cè)試queue=new LinkedList (); for(int i=0;i!=values.length;i++){ queue.offer(values[i]); } return reconPreOrder(queue); } public Node reconPreOrder(Queue queue){ String value=queue.poll(); if(value.equals("#")){ return null; } Node head=new Node(Integer.valueOf(value)); head.left=reconPreOrder(queue); head.right=reconPreOrder(queue); return head; } /*層序序列化*/ public String serialLevel(Node head){ if(head==null){ return "#!"; } String res=head.data+"!"; Queue queue=new LinkedList (); queue.offer(head); while(!queue.isEmpty()){ head=queue.poll(); if(head.left!=null){ res+=head.left.data+"!"; queue.offer(head.left); }else{ res+="#!"; } if(head.right!=null){ res+=head.right.data+"!"; queue.offer(head.right); }else{ res+="#"; } } return res; } /*層序反序列化*/ public Node reconLevel(String str){ String[] values=str.split("!"); int index=0; Node head=createNode(values[index++]); Queue queue=new LinkedList (); if(head!=null){ queue.offer(head); } Node node=null; while(!queue.isEmpty()){ node=queue.poll(); node.left=createNode(values[index++]); node.right=createNode(values[index++]); if(node.left!=null){ queue.offer(node.left); } if(node.right!=null){ queue.offer(node.right); } } return head; } public Node createNode(String val){ if(val.equals("#")){ return null; } return new Node(Integer.valueOf(val)); } } public class test { public static void main(String[] args) { BinaryTree binTree=new BinaryTree(); //建立一棵二叉樹(shù) int[] data={25,15,10,5,36,65,52,45,42}; for(int i=0;i參考資料 《IT名企算法與數(shù)據(jù)結(jié)構(gòu)題目最優(yōu)解》左程云
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/65166.html
摘要:另外,由于篇幅有限,本篇的重點(diǎn)在于二叉樹(shù)的常見(jiàn)算法以及實(shí)現(xiàn)。常見(jiàn)的二叉樹(shù)實(shí)現(xiàn)代碼之前寫(xiě)過(guò)相關(guān)的文章,是關(guān)于如何創(chuàng)建及遍歷二叉樹(shù)的,這里不再贅述。同時(shí)我們注意到,在二叉樹(shù)深度比較大的時(shí)候,我們光是比較左右是不夠的。 本篇為復(fù)習(xí)過(guò)程中遇到過(guò)的總結(jié),同時(shí)也給準(zhǔn)備面試的同學(xué)一份參考。另外,由于篇幅有限,本篇的重點(diǎn)在于二叉樹(shù)的常見(jiàn)算法以及實(shí)現(xiàn)。 常見(jiàn)的二叉樹(shù)實(shí)現(xiàn)代碼 之前寫(xiě)過(guò)相關(guān)的文章,是關(guān)于如...
摘要:什么是樹(shù)前面說(shuō)到的幾種數(shù)據(jù)結(jié)構(gòu)都是線性的,例如鏈表?xiàng)j?duì)列等,今天就來(lái)學(xué)習(xí)一種非線性的數(shù)據(jù)結(jié)構(gòu)樹(shù)。在上圖中的幾種二叉樹(shù)中,有兩個(gè)是比較特殊的,分別是滿二叉樹(shù)和完全二叉樹(shù)。除了使用數(shù)組存儲(chǔ)二叉樹(shù)外,最常用的便是使用鏈表法來(lái)儲(chǔ)存二叉樹(shù)了。 1. 什么是樹(shù)? 前面說(shuō)到的幾種數(shù)據(jù)結(jié)構(gòu)都是線性的,例如鏈表、棧、隊(duì)列等,今天就來(lái)學(xué)習(xí)一種非線性的數(shù)據(jù)結(jié)構(gòu)——樹(shù)。先來(lái)看看幾種樹(shù)的結(jié)構(gòu): showImg(...
摘要:并且,我們的底層都是紅黑樹(shù)來(lái)實(shí)現(xiàn)的。紅黑樹(shù)是一種平衡二叉樹(shù)因此它沒(méi)有節(jié)點(diǎn)。 前言 聲明,本文用得是jdk1.8 前面已經(jīng)講了Collection的總覽和剖析List集合: Collection總覽 List集合就這么簡(jiǎn)單【源碼剖析】 原本我是打算繼續(xù)將Collection下的Set集合的,結(jié)果看了源碼發(fā)現(xiàn):Set集合實(shí)際上就是HashMap來(lái)構(gòu)建的! showImg(https:/...
摘要:所以,如果中序遍歷二叉搜索樹(shù),會(huì)得到一個(gè)有序的數(shù)據(jù),時(shí)間復(fù)雜度是,所以二叉搜索樹(shù)又叫做二叉排序樹(shù)。所以,我們需要一種方式來(lái)維持二叉樹(shù)的平衡,最好是將其維持為滿二叉樹(shù)或者完全二叉樹(shù),這就是后面會(huì)說(shuō)到的平衡二叉查找樹(shù),常見(jiàn)的有樹(shù),紅黑樹(shù)。 1. 概述 前面的文章說(shuō)到了二叉樹(shù),其實(shí)今天講的二叉搜索(查找)樹(shù)就是二叉樹(shù)最常用的一種形式,它支持高效的查找、插入、刪除操作,它的定義是這樣的:對(duì)于樹(shù)...
閱讀 1530·2021-11-23 09:51
閱讀 3643·2021-09-26 09:46
閱讀 2131·2021-09-22 10:02
閱讀 1842·2019-08-30 15:56
閱讀 3326·2019-08-30 12:51
閱讀 2233·2019-08-30 11:12
閱讀 2068·2019-08-29 13:23
閱讀 2329·2019-08-29 13:16