首页 > 其他分享 >二叉树的线索化与遍历

二叉树的线索化与遍历

时间:2023-05-08 21:15:41浏览次数:40  
标签:遍历 return val 线索 二叉树 null root public TreeNode2

废话不说,上代码l

  1 package dataSrtuct.TreeAlgorithm;
  2 
  3 import com.sun.source.tree.Tree;
  4 
  5 public class ThreadBinaryTree {
  6     public static void main(String[] args) {
  7         TreeNode2 root = new TreeNode2(1, "M");
  8         TreeNode2 node2 = new TreeNode2(3, "N");
  9         TreeNode2 node3 = new TreeNode2(6, "O");
 10         TreeNode2 node4 = new TreeNode2(8, "P");
 11         TreeNode2 node5 = new TreeNode2(10, "Q");
 12         TreeNode2 node6 = new TreeNode2(14, "Z");
 13         root.setLeftNext(node2);
 14         root.setRightNext(node3);
 15         node2.setLeftNext(node4);
 16         node2.setRightNext(node5);
 17         node3.setLeftNext(node6);
 18         TBinaryTree tBinaryTree = new TBinaryTree();
 19         tBinaryTree.setRoot(root);
 20         tBinaryTree.infixOrder();
 21         tBinaryTree.threadBinaryTree(root);
 22         System.out.println("node5的前驱结点是:"+node6.getLeftNext().getVal());
 23         System.out.println("node5的后继结点是:"+node6.getRightNext().getVal());
 24         System.out.println("node4的前驱结点是:"+node4.getLeftNext());
 25         tBinaryTree.threadBinaryTreePrint();
 26 
 27     }
 28 }
 29 //线索化二叉树
 30 class TBinaryTree{
 31     private TreeNode2 root;
 32     private TreeNode2 preNode;
 33     public TreeNode2 getRoot() {
 34         return root;
 35     }
 36 
 37     public void setRoot(TreeNode2 root) {
 38         this.root = root;
 39     }
 40 
 41     /**
 42      * 遍历线索话二叉树
 43      */
 44     public void threadBinaryTreePrint(){
 45         TreeNode2 node=this.root;
 46         while (node!=null){
 47             while (node.getLeftNodeType()==0){
 48                 node=node.getLeftNext();
 49             }
 50             System.out.println(node);
 51             while (node.getRightNodeType()==1){
 52                 node=node.getRightNext();
 53                 System.out.println(node);
 54             }
 55             node=node.getRightNext();
 56         }
 57     }
 58     /**
 59      *线索化二叉树
 60      * @param node 当前节点
 61      */
 62     public void threadBinaryTree(TreeNode2 node){
 63         if (node==null)
 64             return;
 65         threadBinaryTree(node.getLeftNext());
 66         if (node.getLeftNext()==null) {
 67             node.setLeftNext(preNode);
 68             node.setLeftNodeType(1);
 69         }
 70         if (preNode!=null&&preNode.getRightNext()==null) {
 71             preNode.setRightNext(node);
 72             preNode.setRightNodeType(1);
 73         }
 74         //整个线索化代码最难的地方,因为你的一个节点指定完前驱和后继之后一定会成为前驱节点,
 75         preNode=node;
 76         threadBinaryTree(node.getRightNext());
 77     }
 78     //先序遍历
 79     public void preOrder(){
 80         if (this.root!=null)
 81             this.root.preOrder();
 82         else
 83             System.out.println("二叉树为空,不能遍历");
 84     }
 85     ///中序遍历
 86     public void infixOrder(){
 87         if (this.root!=null)
 88             this.root.infixOrder();
 89         else
 90             System.out.println("二叉树为空,不能遍历");
 91     }
 92     //后序遍历
 93     public void postOrder(){
 94         if (this.root!=null)
 95             this.root.postOrder();
 96         else
 97             System.out.println("二叉树为空,不能遍历");
 98     }
 99     //前、后、中序查找
100     //先序查找
101     public TreeNode2 preOrderSearch(int val){
102         if (this.root!=null)
103             return this.root.preOrderSearch(val);
104         else {
105             System.out.println("二叉树为空,不能遍历");
106             return null;
107         }
108     }
109     //中序查找
110     public TreeNode2 infixOrderSearch(int val){
111         if (this.root!=null)
112             return this.root.infixOrderSearch(val);
113         else {
114             System.out.println("二叉树为空,不能遍历");
115             return null;
116         }
117     }
118     //后序查找
119     public TreeNode2 postOrderSearch(int val){
120         if (this.root!=null)
121             return this.root.postOrderSearch(val);
122         else {
123             System.out.println("二叉树为空,不能遍历");
124             return null;
125         }
126 
127     }
128 }
129 //创建各个节点
130 class TreeNode2{
131     private int val;
132     private String name;
133     //0为指向树,1为事项前后节点
134     private TreeNode2 leftNext;
135     private TreeNode2 rightNext;
136     private int leftNodeType;
137     private int rightNodeType;
138     public static int countPre;
139     public static int countInfix;
140     public static int countPost;
141     static {
142         countPre=0;
143         countInfix=0;
144         countPost=0;
145     }
146 
147     public TreeNode2(int val, String name) {
148         this.val = val;
149         this.name = name;
150     }
151 
152     public int getLeftNodeType() {
153         return leftNodeType;
154     }
155 
156     public void setLeftNodeType(int leftNodeType) {
157         this.leftNodeType = leftNodeType;
158     }
159 
160     public int getRightNodeType() {
161         return rightNodeType;
162     }
163 
164     public void setRightNodeType(int rightNodeType) {
165         this.rightNodeType = rightNodeType;
166     }
167 
168     public int getVal() {
169         return val;
170     }
171 
172     public void setVal(int val) {
173         this.val = val;
174     }
175 
176     public String getName() {
177         return name;
178     }
179 
180     public void setName(String name) {
181         this.name = name;
182     }
183 
184     public TreeNode2 getLeftNext() {
185         return leftNext;
186     }
187 
188     public void setLeftNext(TreeNode2 leftNext) {
189         this.leftNext = leftNext;
190     }
191 
192     public TreeNode2 getRightNext() {
193         return rightNext;
194     }
195 
196     public void setRightNext(TreeNode2 rightNext) {
197         this.rightNext = rightNext;
198     }
199 
200     @Override
201     public String toString() {
202         return "TreeNode2{" +
203                 "val=" + val +
204                 ", name='" + name + '\'' +
205                 '}';
206     }
207     //先序查找
208     public TreeNode2 preOrderSearch(int val){
209         TreeNode2.countPre++;
210         if (this.val==val)
211             return this;
212         TreeNode2 tempNode=null;
213         if (this.leftNext!=null)
214             tempNode=this.leftNext.preOrderSearch(val);
215         if (tempNode!=null)
216             return tempNode;
217         if (this.rightNext!=null)
218             tempNode= this.rightNext.preOrderSearch(val);
219         return tempNode;
220     }
221     //中序查找
222     public TreeNode2 infixOrderSearch(int val){
223         TreeNode2.countInfix++;
224         TreeNode2 tempNode=null;
225         if (this.leftNext!=null)
226             tempNode=this.leftNext.infixOrderSearch(val);
227         if (tempNode!=null)
228             return tempNode;
229         if (this.val==val)
230             return this;
231         if (this.rightNext!=null)
232             tempNode=this.rightNext.infixOrderSearch(val);
233         return tempNode;
234     }
235     //后序查找
236     public TreeNode2 postOrderSearch(int val){
237         TreeNode2.countPost++;
238         TreeNode2 tempNode=null;
239         if (this.leftNext!=null)
240             tempNode=this.leftNext.postOrderSearch(val);
241         if (tempNode!=null)
242             return tempNode;
243         if (this.rightNext!=null)
244             tempNode=this.rightNext.postOrderSearch(val);
245         if (tempNode!=null)
246             return tempNode;
247         if (this.val==val)
248             return this;
249         return tempNode;
250 
251     }
252     //先序遍历
253     public void preOrder(){
254         System.out.println(this);
255         if (this.leftNext!=null)
256             this.leftNext.preOrder();
257         if (this.rightNext!=null)
258             this.rightNext.preOrder();
259     }
260     ///中序遍历
261     public void infixOrder(){
262         if (this.leftNext!=null)
263             this.leftNext.infixOrder();
264         System.out.println(this);
265         if (this.rightNext!=null)
266             this.rightNext.infixOrder();
267     }
268     //后序遍历
269     public void postOrder(){
270         if (this.leftNext!=null)
271             this.leftNext.postOrder();
272         if (this.rightNext!=null)
273             this.rightNext.postOrder();
274         System.out.println(this);
275     }
276 }

 

标签:遍历,return,val,线索,二叉树,null,root,public,TreeNode2
From: https://www.cnblogs.com/Mexcellent/p/17383138.html

相关文章

  • 线索二叉树
    (39条消息)线索二叉树,画图教你秒懂线索二叉树(线索二叉树的建立和简单操作)逻辑代码分析_IC00的博客-CSDN博客摘自这位大佬的内容,感觉写的很不错......
  • C/C++二叉树应用[2023-05-08]
    C/C++二叉树应用[2023-05-08]湖南应用技术学院实验(训)报告课程名称 数据结构与算法 课程代码 221031203 成绩评定 学院 信息工程学院 专业 物联网工程 指导老师 聂作财学生姓名 xxxx 学号 xxxxx 班级 物联xxxx实验地点 实验日期 年月日小组成员 无实验类型 □验......
  • leetcode 101 对称二叉树 Simple
    题目给你一个二叉树的根节点root,检查它是否轴对称。输入:root=[1,2,2,3,4,4,3]输出:true输入:root=[1,2,2,null,3,null,3]输出:false题解考察二叉树的遍历,使用广度优先BFS方法.BFS的关键在于使用队列,遍历树时,读到的节点先入队,再出队,出队时读取值,放入结......
  • hdu 1599 find the mincost route(无向图的最小环:求从一个点遍历所有节点以后回到原点
    题目:findthemincostrouteTimeLimit:1000/2000MS(Java/Others)    MemoryLimit:32768/32768K(Java/Others)TotalSubmission(s):2801    AcceptedSubmission(s):1115ProblemDescription杭州有N个景区,景区之间有一些双向的路来连接,现在8600想找一条旅游......
  • (第26章)LinuxC本质中链表、二叉树和哈希表
    文章目录一、单链表的结构决定只能出栈,入栈1.链表的结构2.链表与数组的区别3.单链表所有基本操作代码(1)链表的插入(2)链表的查找(3)链表的删除(3)遍历整个链表(4)销毁整个链表4.习题5.C++NULL指针二、双向链表结构决定可以出队和入队1.在上面的单项链表上改改,得到双向链表2.改进双向链表:新增......
  • 平衡二叉树
    classSolution{public:boolres=true;intdfs(TreeNode*root)//返回以root为根节点的子树深度{if(root==NULL)return0;intl=dfs(root->left),r=dfs(root->right);if(abs(l-r)>1)res=false;returnmax(l......
  • 树的遍历(traversal)
    Traversal一般指遍历。所谓遍历(Traversal),是指沿着某条搜索路线,依次对树(或图)中每个节点均做一次访问。访问结点所做的操作依赖于具体的应用问题,具体的访问操作可能是检查节点的值、更新节点的值等。不同的遍历方式,其访问节点的顺序是不一.........
  • 1163 Dijkstra Sequence + 层序遍历 + 链式前向星
    PAT题目链接:https://pintia.cn/problem-sets/994805342720868352/exam/problems/1478635670373253120这题踩了太多坑,本来没什么内容,硬是断断续续查了三天的bug:第一天:循环的时候内部判断逻辑不要写在for循环里,否则本该continue的逻辑,硬生生变成了break。我真是脑袋瓜秀逗了才会......
  • 图的遍历(408)
    BFS算法概述:创建一个空队列。从某个点开始,找到该点所指向的所有的点并且没有被标记过的,放入队列中,并且对当前的点做标记,表示被遍历过了。再从队列中取出新的点,重复前面的操作。直到队列为空。由于图不一定是连通的,需要遍历1~n个点。要点:BFS类似于树的层次遍历,由于存储的边的......
  • 线索二叉树
    线索二叉树为什么要研究线索二叉树?如何解决上面的问题?我们使用第三种方法二叉链表当中右很多空的指针域线索二叉树定义例子线索二叉树增设了这些指针之后,会难以区分是指向孩子的指针还是指向前驱结点或者后继结点的指针所以要加上两个标志域线索二叉树的结点结......