二叉树最多只能有两个子节点,也就是说分支度小于或等于2.所谓二叉树的链表表示法,就是利用链表来存储二叉树。
使用链表来表示二叉树的好处是节点的增加与删除操作相对容易,缺点是很难找到父节点,除非在每一节点多增加一个指向父字段。
代码实现:
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; /** * @author admin $ * @title $ * 用链表来实现二叉树 * @description $ * @updateTime $ 12:58$ $ * @throws $ */ public class Tree2 { //主函数 public static void main(String[] args) throws IOException { int ArraySize=10; int tempdata; int []content=new int[ArraySize]; BufferedReader keyin=new BufferedReader(new InputStreamReader(System.in)); System.out.println("请连续输入"+ArraySize+"个数据"); for (int i = 0; i <ArraySize ; i++) { System.out.println("请输入第"+(i+1)+"个数据"); tempdata=Integer.parseInt(keyin.readLine()); content[i]=tempdata; } new BinaryTree(content); System.out.println("====用链表创建二叉树成功=======!!!"); } } //二叉树节点类声明 class TreeNode{ int value; TreeNode left; TreeNode right; //构造函数 public TreeNode(int value){ this.left=null; this.right=null; this.value=value; } } class BinaryTree { public TreeNode rootNode;//二叉树的根节点 //构造函数:利用传入一个数组的参数来创建二叉树 public BinaryTree(int[] data) { for (int i = 0; i < data.length; i++) { Add_Node_To_Tree(data[i]); } } //将指定的值加入到二叉树中适当的节点 private void Add_Node_To_Tree(int value) { TreeNode currentNode = rootNode; if (rootNode == null) {//创建树根 rootNode = new TreeNode(value); return; } //创建二叉树 while (true) { if (value < currentNode.value) { if (currentNode.left == null) { currentNode.left = new TreeNode(value); return; } else currentNode = currentNode.left; } else { //右子树 if (currentNode.right == null) { currentNode.right = new TreeNode(value); return; } else currentNode = currentNode.right; } } } }
最后
以上就是耍酷帆布鞋最近收集整理的关于用链表来实现二叉树的全部内容,更多相关用链表来实现二叉树内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复