数据结构二叉树的三种遍历方式

package com.test;


public class Node {
public String data;
public Node lchid;
public Node rchid;


public Node(String data, Node lchid, Node rchid) {
this.data = data;
this.lchid = lchid;
this.rchid = rchid;
}


}package com.test;


import java.util.ArrayList;
import java.util.List;
import com.test.Node;
public class Tree {
public  Node root;
private List<Node> list = new ArrayList<Node>();


public Tree() {
init();
}


public void init() {
Node x = new Node("X", null, null);
Node y = new Node("Y", null, null);
Node d = new Node("d", x, y);
root = d;
}


public void preorder(Node node) {
list.add(node);
if (node.lchid != null) {
preorder(node.lchid);
}
if (node.rchid != null) {
preorder(node.rchid);
}
}


public void middleorder(Node node) {
if (node.lchid != null) {
middleorder(node.lchid);
}
list.add(node);
if (node.rchid != null) {
middleorder(node.rchid);
}


}
public  void afterorder(Node node){
if(node.lchid!=null){
afterorder(node.lchid);
}
if(node.rchid!=null){
afterorder(node.rchid);
}
list.add(node);
}
public List<Node> getResult(){
return list;

}
public static void main(String[] args) {
Tree tree=new Tree();
//tree.afterorder(tree.root);
tree.middleorder(tree.root);
for(Node node:tree.getResult()){
System.out.println(node.data);
}
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值