二叉排序树(北京邮电大学-2012)

转载 2016年08月30日 18:51:17

主类:

import bst.*;
public class BinarySearch
{
    public static void main(String[] args)
    {
        Scanner scan = new Scanner(System.in);
        List<BST> list = new ArrayList<BST>();
        BST<Integer,Integer> bst = new BST<Integer,Integer>();
        while(scan.hasNext())
        {
            int number = scan.nextInt();
            for(int i=0;i<number;i++)
            {
                bst.put(scan.nextInt(),number);
            }
            list.add(bst);
        }
        //bst.inOrderTraverse();
        for(int i=0;i<list.size();i++)
        {
            list.get(i).preOrderTraverse();
        }
    }

sort包中的BST类:

public class BST<Key extends Comparable<Key>,Value>
{
    private  Node root;
    public Key getRoot(){
        return root.getKey();
    }

    //BST插入算法
    public void put(Key key,Value val)
    {
        root = put(root,key,val);
    }
    public Node put(Node x,Key key,Value 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.N =size(x.left)+size(x.right)+1;
        return x;
    }
    //BST查找算法
    public Value get(Key key)
    {
        Node x =root;
        while(x!=null)
        {
            int cmp = key.compareTo(x.key);
            if(cmp<0) x= x.left;
            else if(cmp>0) x = x.right;
            else return x.val;
        }
        return null;
    }
    //BST删除算法
    public void delete(Key key)
    {   
        root = delete(root,key);
    }
    public Node delete(Node x,Key key)
    {
        if(x==null) return null;
        int cmp = key.compareTo(x.key);
        if     (cmp < 0) x.left = delete(x.left,key);
        else if(cmp>0) x.right = delete(x.right,key);
        else
        {
            if(x.right == null) return x.left;
            if(x.left == null) return x.right;
            Node t = x;
            x = min(t.right);
            x.right = deleteMin(t.right);
            x.left = t.left;
        }
        x.N = size(x.left) + size(x.right) + 1;
        return x;
    }
    //BST最小键求法
    public Key min()
    {
        return min(root).key;
    }
    public Node min(Node x)
    {
        if(x.left == null) return x;
        return min(x.left);
    }
    //BST删除最小值算法
    public void deleteMin()
    {
        root = deleteMin(root);
    }
    private Node deleteMin(Node x)
    {
        if(x.left==null) return x.right;
        x.left = deleteMin(x.left);
        x.N = size(x.left) + size(x.right) + 1;
        return x;
    }
    //先根遍历算法,寻找父亲结点
    public void preOrderTraverse()
    {
         preOrderTraverse(root);
    }
    private void preOrderTraverse(Node x)
    {
        Node T = x;
        if(T==null) return;
        if(x.left!=null) x.left.setParent(x);
        if(x.right!=null) x.right.setParent(x);
        if(T==this.root) System.out.println("-1"+" ");
        else
            System.out.println(x.getParent().getKey()+" ");
        preOrderTraverse(x.left);
        preOrderTraverse(x.right);
    }
    //中序遍历算法
    public void inOrderTraverse()
    {
        inOrderTraverse(root);
    }
    private void inOrderTraverse(Node root)
    {
        Node T= root;
        if(T==null) return;
        inOrderTraverse(root.left);
        System.out.print(root.key+" ");
        inOrderTraverse(root.right);
    }
    //返回总结点个数
    public int size()
    {
        return size(root);
    }
    public int size(Node x)
    {
        if(x == null) return 0;
        else return x.N;
    }


    private class Node
    {
        private Key key;
        private Value val;
        private Node parent,left,right; 
        private int N;

        public Node(Key key,Value val,int N)
        {
            this.key = key;
            this.val = val;
            this.N = N;
        }
        public Node getParent()
        {
            return this.parent;
        }
        public void setParent(Node parent)
        {
            this.parent = parent;
        }
        public Key getKey()
        {
            return this.key;
        }
        public void setKey(Key key)
        {
            this.key = key;
        }



    }   
}

结果

相关文章推荐

北京邮电大学2012年接收推荐免试攻读硕士学位研究生的办法

【发表时间:2011-09-14 16:01:56】 【浏览次数:2319】                     一、 申请条件 1.         拥护中国共产党的...

北京邮电大学课程Java实验一

**Project #1 A math learning tool** Develop a program that lets a first grader practice additions. ...

北京邮电大学2010年计算机方向复试上机题 解题报告

九度OJ 题目1169:比较奇偶数个数 时间限制:1 秒  内存限制:32 兆  特殊判题:否  提交:1368  解决:329 题目描述:     第一行输入一个数,为n,第二行输入n个...

北京邮电大学校长方滨兴在今年本科生毕业典礼上讲话

同学们,大家上午好!(掌声)   今天,我们在这里举行一年一度的本科生毕业典礼,虽然每年的校历都镌刻着这个日子,对教师们来说习以为常,但对你们来说却非同寻常。因为这是你们人生中一个重要的标志,是你们...

网络信息安全对抗(北京邮电大学版)考点总结

你敢酱油党,一本书一天总结考点,就这样总结出来了!!!!     作业1:通过社会工程学手段尝试获知异性同学的a)生肖b)星座c)出生日期d)生辰八字(bonus: 2分),并详述你的社会工...

北京邮电大学2011年网院方向复试上机题 解题报告

九度OJ 题目1177:查找 时间限制:1 秒  内存限制:32 兆  特殊判题:否  提交:554  解决:130 题目描述:         读入一组字符串(待操作的),再读入一个int...

北京邮电大学世纪学院CSDN高校俱乐部新学期纳新工作圆满完成

北京邮电大学世纪学院CSDN编程社(暨高校俱乐部)成立于2006年,与CSDN正式取得合作在2013年9月。俱乐部主要以提高同学对计算机编程的热情,以及鼓励同学们积极参与各项专业竞赛和社会活动为目的,...
  • nf1994
  • nf1994
  • 2013年10月25日 10:37
  • 1013

北京邮电大学CSDN高校俱乐部运营策划

北邮CSDN俱乐部运营策划书 俱乐部名称:北京邮电大学CSDN俱乐部 定位: 北邮CSDN俱乐部旨在建立一个有利于IT技术分享学习的团体,让大家更好的认识和利用CSDN社区提供的资源提升自己的能力,扩...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:二叉排序树(北京邮电大学-2012)
举报原因:
原因补充:

(最多只允许输入30个字)