二叉樹

閑來沒事,學習了下二叉樹



public class TreeNode {

/**

* 左邊節點

*/

public TreeNode leftTree;

/**

* 右邊節點

*/

public TreeNode rightTree;

/**

* 數據

*/

public int iDate;

public int parent;

public TreeNode(int i) {

// TODO Auto-generated constructor stub

this.iDate = i;

}

public void displayNode() {

}

public void add(TreeNode root, int idate) {

// parent=root;

TreeNode node = find(root, idate);

if (node != null) {

if (node.iDate < idate) {

node.rightTree = new TreeNode(idate);

node.rightTree.parent=node.iDate;

} else {

node.leftTree = new TreeNode(idate);

node.leftTree.parent=node.iDate;

}

}

}

private TreeNode find(TreeNode root, int i) {

// TODO Auto-generated method stub

if (root.iDate < i) {

if (root.rightTree != null) {

return find(root.rightTree, i);

} else {

return root;

}

} else {

if (root.leftTree != null) {

return find(root.leftTree, i);

} else {

return root;

}

}

}

}


----------------------------------


public class TreeTest {

public static int[] temp={7,3,9,8,10,2,1};

public static void main(String[] args) {

TreeNode node=new TreeNode(5);

for (int i = 0; i < temp.length; i++) {

node.add(node,temp[i]);

}

System.out.println(node);

// node.find(3);

}

}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容