二叉树的基础实现 代码

 class BinaryTree <T extends Comparable<T>>{
	private class Node{
		private Comparable<T> data;//可以比较大小
		private Node parent;//保存父节点
	    private Node left;
	    private Node right;
	    public Node(Comparable<T> data) {
	    	this.data=data;
	    }
	    public void addNode(Node newNode) {
                 if(newNode.data.compareTo((T)this.data)<=0) {
                	 if(this.left==null) {
                		 this.left=newNode;
                		 newNode.parent=this;
                	 }else {
                		 this.left.addNode(newNode);
                	 }
                	 
                 }else {
                	 if(this.right==null) {
                		 this.right=newNode;
                		 newNode.parent=this;
                	 }else {
                		 this.right.addNode(newNode);
                	 }  
             
                 }
                 }
	    public void toArrayNode() {
                if(this.left !=null) {
	                this.left.toArrayNode();
                          }
                BinaryTree.this.returnData[BinaryTree.this.foot ++]=this.data;
                        if(this.right !=null) {
                        	this.right.toArrayNode();
                        }
	    
	}
}
	private Node root;/** * 进行数据的保存 */
	private int count=0;
	private Object[] returnData;//返回的数据
	private int foot =0;
	
	public void add(Comparable<T> data) {
		if(data==null) {
			throw new NullPointerException("保存的数据不能为空");	
		}
		Node newNode=new Node(data);
		if(this.root==null) {
			this.root=newNode;
		}else {
			this.root.addNode(newNode);
			
		}
		this.count++;
	}
	
	public Object[] toArray() {
		if(this.count==0) {
			return null;
		}
		this.returnData=new Object[this.count ];
		this.foot=0;
		this.root.toArrayNode();	
		return this.returnData;
	}
}
 class Person implements Comparable<Person>{
	 private String name;
	 private int age;
	 public Person(String name,int age) {
		 this.name=name;
		 this.age=age;
	 }
	@Override
	public int compareTo(Person per) {
		 
		return this.age-per.age;
	}
	 
	public String toString() {
		return "【Person对象】姓名"+this.name+"年龄"+this.age+"\n";
	}
 }
public class Test1 {
 public static void main(String[] args) throws Exception {
 BinaryTree<Person> tree = new BinaryTree<Person>();
Person p1 = new Person("zhangsan", 32);
Person p2 = new Person("lili", 47);
Person p3 = new Person("lisi", 93);
Person p4 = new Person("wangwu", 12);
Person p5 = new Person("xiaoming", 38);
tree.add(p1);
tree.add(p2);
tree.add(p3);
tree.add(p4);
tree.add(p5);
System.out.println(Arrays.toString(tree.toArray()));
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值