0 课程地址
https://coding.imooc.com/lesson/207.html#mid=13456
1 重点关注
1.1 代码草图
1.2 二分搜索树添加元素 代码简化
见3.1
2 课程内容
3 Coding
3.1 二分搜索树添加元素 代码简化
- 关键代码
//2 循环添加元素,把null也看作节点 public void add(E e){ root = add(e,root); } //3 递归,添加元素 public Node add(E e,Node root){ //3.1 终止条件 if(root==null){ size++; return new Node(e); } //3.2 递归 //3.2.1 递归左孩子 if(e.compareTo(root.e)<0){ root.left = add(e,root.left); } //3.2.2 递归右孩子 if(e.compareTo(root.e)>0){ root.right = add(e,root.right); } //点睛之笔 return root; }
- 全量代码
package com.company; public class BST2<E extends Comparable> { //1 内部类 private class Node{ //二叉树特有属性 private Node left,right; private E e; private Node(E e){ this.e = e; this.left = null; this.right = null; } } private int size; private Node root; public BST2(){ this.size = 0; this.root = null; } /** * 定义基本方法 getSize * @author weidoudou * @date 2022/11/3 12:57 * @return int **/ public int getSize(){ return size; } /** *查询是否为空 * @author weidoudou * @date 2022/11/3 12:58 * @return boolean **/ public boolean isEmpty(){ return size == 0; } //2 循环添加元素,把null也看作节点 public void add(E e){ root = add(e,root); } //3 递归,添加元素 public Node add(E e,Node root){ //3.1 终止条件 if(root==null){ size++; return new Node(e); } //3.2 递归 //3.2.1 递归左孩子 if(e.compareTo(root.e)<0){ root.left = add(e,root.left); } //3.2.2 递归右孩子 if(e.compareTo(root.e)>0){ root.right = add(e,root.right); } //点睛之笔 return root; } }
诸葛