Save BST to a file

本文介绍了一种利用先序遍历(preorder traversal)的方式将二叉搜索树(Binary Search Tree, BST)保存到文件中,并从文件中恢复的方法。通过递归地构建节点,确保每个节点的值都在其父节点规定的范围内,从而保证了重建的BST结构正确。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://articles.leetcode.com/2010/09/saving-binary-search-tree-to-file.html


preorder traversal将bst存下来。

如何恢复?依然preorder。母节点的数值决定了子节点可以存储的范围,所以我们拿到一个新的数字时,看他是不是在母节点的规定范围内;否则就继续到母节点的另外一个子树中尝试。

时间复杂度分析:O(n),和preorder traversal是一样的访问顺序,只是每次多了一次比较

public static BST readBST(String fileName) throws Exception {
    BufferedReader fin = new BufferedReader(new FileReader(fileName));
    data = Integer.parseInt(fin.readline());
    bst = new BST();
    bst.root = new Node(-1, null, null);
    buildBST(bst.root, new int[] {data,}, Integer.MIN_VALUE, Integer.MAX_VALUE, fin);
}
private void buildBST(Node node, int[] data, int low, int high, BufferedReader fin) {
    if (data[0] > low && data[0] < high) {
        node.data = data[0];
        try {
            data[0] = Integer.parseInt(fin.readline());
            if (data[0] > low && data[0] < node.data) {
                node.left = new Node(-1, null, null);
                buildBST(node.left, data, low, node.data, fin);
            }
            if (data[0] > node.data && data[0] < high) {
                node.right = new Node(-1, null, null);
                buildBST(node.right, data, node.data, high, fin);
            }
    <span style="white-space:pre">	</span>} catch (Exception e) {}
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值