91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

二叉搜索樹迭代器指的是什么

發布時間:2022-01-15 11:29:04 來源:億速云 閱讀:87 作者:柒染 欄目:大數據

這篇文章給大家介紹二叉搜索樹迭代器指的是什么,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

實現一個二叉搜索樹迭代器。你將使用二叉搜索樹的根節點初始化迭代器。

調用 next() 將返回二叉搜索樹中的下一個最小的數。

示例:

二叉搜索樹迭代器指的是什么

BSTIterator iterator = new BSTIterator(root); iterator.next();    

// 返回 3 iterator.next();    

// 返回 7 iterator.hasNext(); 

// 返回 true iterator.next();    

// 返回 9 iterator.hasNext(); 

// 返回 true iterator.next();    

// 返回 15 iterator.hasNext(); 

// 返回 true iterator.next();    

// 返回 20 iterator.hasNext(); 

// 返回 false

答案:

 1class BSTIterator {
2
3    private Stack<TreeNode> stack = new Stack<TreeNode>();
4
5    public BSTIterator(TreeNode root) {
6        pushAll(root);
7    }
8
9    public boolean hasNext() {
10        return !stack.isEmpty();
11    }
12
13    public int next() {
14        TreeNode tmpNode = stack.pop();
15        pushAll(tmpNode.right);
16        return tmpNode.val;
17    }
18
19    private void pushAll(TreeNode node) {
20        for (; node != null; stack.push(node), node = node.left) ;
21    }
22}

解析:
如果對二叉樹的dfs(深度優先搜索)比較熟悉的話,這題很容易理解。

關于二叉搜索樹迭代器指的是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

朝阳市| 永州市| 丹江口市| 青海省| 铜山县| 新晃| 个旧市| 仁化县| 腾冲县| 衡水市| 鹤山市| 云阳县| 大荔县| 白水县| 周至县| 开封县| 克东县| 泰顺县| 澄城县| 广元市| 饶河县| 崇左市| 疏勒县| 新建县| 合阳县| 靖江市| 辰溪县| 洛扎县| 新密市| 拉萨市| 韶关市| 梓潼县| 越西县| 贵德县| 嘉荫县| 孙吴县| 沭阳县| 泽州县| 保德县| 那曲县| 汝南县|