java 裏關於二叉樹排序的問題

二叉樹排序算法的實現html

//節點類java

public class Node {
	private Node left;
	private Node right;
	private int data;
	public Node(int data){
		this.data=data;
	}
	public void addNode(Node newNode){
		if(newNode.data<this.data){
			if(this.left==null){
				this.left=newNode;
			}else{
				this.left.addNode(newNode);
			}
		}
		if(newNode.data>=this.data){
			if(this.right==null){
				this.right=newNode;
			}else{
				this.right.addNode(newNode);
			}
		}
	}
	public void printNode(){
		if(this.left!=null){
			this.left.printNode();  
		}
		System.out.print(this.data+"\t");
		if(this.right!=null){
			this.right.printNode();
		}
	}
}

//聲明一個二叉樹算法

class BinaryTree {
	private Node root;
	public void add(int data){
		Node newNode=new Node(data);
		if(root==null){
			root=newNode;
		}else{
			root.addNode(newNode);
		}
	}
	public void print(){
		this.root.printNode();
	} 
}

//測試二叉樹排序TestBinaryTree測試

public class TestBinaryTree {
	public static void main(String[] args) {
		BinaryTree bt = new BinaryTree();
		bt.add(3);
		bt.add(4);
		bt.add(5);
		bt.add(6);
		bt.add(0);
		bt.add(7);
		bt.add(1);
		bt.add(9);
		bt.add(-3);
		bt.print();
	}
}

結果是this

-3	0	1	3	4	5	6	7	9
相關文章
相關標籤/搜索