java - 关于二叉查找树的put方法
大家讲道理
大家讲道理 2017-04-18 10:05:44
0
1
654

看二叉查找树的时候看到put方法:

 public void put(Key key, Value val) {
        if (key == null) throw new NullPointerException("first argument to put() is null");
        if (val == null) {
            delete(key);
            return;
        }
        root = put(root, key, val);
        assert check();
    }

    private Node put(Node x, Key key, Value val) {
        //if key存在于以x为结点的子树中则更新它的值
        //then 将以key和val为键值的新结点插入到该子树中
        if (x == null) return new Node(key, val, 1);
        int cmp = key.compareTo(x.key);
        //比它小往左边走
        if      (cmp < 0) x.left  = put(x.left,  key, val);
        //不然往右边走
        else if (cmp > 0) x.right = put(x.right, key, val);
        //找到了就赋新的值
        else              x.val   = val;
        x.size = 1 + size(x.left) + size(x.right);//为什么要+1???
        return x;
    }

为什么要x.size = 1 + size(x.left) + size(x.right);??进入这里的条件是如果该结已存在就赋予新的值吧?那么仅仅是更新一个值为什么要增加1个size呢?

大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

모든 응답(1)
刘奇

주석에 문제가 있습니다. 이진 검색 트리의 경우 실제로 삽입을 의미합니다.

  1. cmp < 0 || cmp > 0이면 왼쪽 하위 트리 또는 오른쪽 하위 트리에 노드가 하나 더 생기고 크기가 1 증가합니다.

  2. cmp==0이면 중복 노드를 추가하는 것과 같습니다. 일반적인 상황에서 는 트리에 중복 노드를 추가하지 않고 현재 node.size에 1을 추가합니다.

최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!