97. 二叉排序树

时间限制 1000 ms 内存限制 65536 KB

题目描述

二叉排序树,也称为二叉查找树。可以是一颗空树,也可以是一颗具有如下特性的非空二叉树:

  1. 若左子树非空,则左子树上所有节点关键字值均不大于根节点的关键字值;
  2. 若右子树非空,则右子树上所有节点关键字值均不小于根节点的关键字值;
  3. 左、右子树本身也是一颗二叉排序树。

现在给你N个关键字值各不相同的节点,要求你按顺序插入一个初始为空树的二叉排序树中,每次插入后成功后,求相应的父亲节点的关键字值,如果没有父亲节点,则输出-1。

输入格式

第一行,一个数字N(N<=100),表示待插入的节点数。

第二行,N个互不相同的正整数,表示要顺序插入节点的关键字值,这些值不超过108。

输出格式

输出共N行,每次插入节点后,该节点对应的父亲节点的关键字值

输入样例

5
2 5 1 3 4

输出样例

-1
2
2
5
3

不是很难的题但确实体现了北邮爱考树相关的编程题,从历年的初试题也能看得出来。

用类表示节点,在节点内部定义父节点。

用节点数组按输入顺序存储节点。

在递归创建二叉排序树的时候,记录父节点。

package test;

import java.io.BufferedInputStream;
import java.util.Scanner;
class NODE1{
int value;
NODE1 father;
NODE1 left;
NODE1 right;
public int getValue() {
return value;
}
public void setValue(int value) {
this.value = value;
}
public NODE1 getFather() {
return father;
}
public void setFather(NODE1 father) {
this.father = father;
}
public NODE1 getLeft() {
return left;
}
public void setLeft(NODE1 left) {
this.left = left;
}
public NODE1 getRight() {
return right;
}
public void setRight(NODE1 right) {
this.right = right;
}
public NODE1(int value, NODE1 father, NODE1 left, NODE1 right) {
super();
this.value = value;
this.father = father;
this.left = left;
this.right = right;
} }
public class ErchashuMain { public static void main(String[] args) {
Scanner scan = new Scanner (new BufferedInputStream(System.in));
int T = scan.nextInt(); NODE1 root = new NODE1(scan.nextInt(),null, null, null);
NODE1 [] nodes = new NODE1[T];
nodes[0] = root;
root.father = new NODE1(-1,null, null, null);
for(int i=1;i<T;i++){
nodes[i] = new NODE1(scan.nextInt(),null, null, null);
Insert(nodes[i],root);
}
for(int i=0;i<T;i++){ System.out.println(nodes[i].father.value);
}
} private static int Insert(NODE1 tarnode, NODE1 root) {
if(tarnode.value<root.value){
if(root.left!=null){
Insert(tarnode,root.left);
}else{
tarnode.father = root;
root.left = tarnode;
return 1;
} }
if(tarnode.value>root.value){
if(root.right!=null){
Insert(tarnode,root.right);
}else{
tarnode.father = root;
root.right = tarnode;
return 1;
} }
return 1; } }

最新文章

  1. MVC中的@符号
  2. LeetCode 【235. Lowest Common Ancestor of a Binary Search Tree】
  3. python实现curl功能
  4. 记录整合sprinmvc+log4j的的过程
  5. SVG 2D入门7 - 重用与引用
  6. scikit learn 模块 调参 pipeline+girdsearch 数据举例:文档分类 (python代码)
  7. C#操作Excel开发报表系列整理(转)
  8. 当MVC4无法跳转时
  9. Linux环境下Android JNI程序的编译
  10. MyBatis Generator 的使用
  11. hdu5652 India and China Origins(并查集)
  12. 网络编程-SOCKET开发之----2. TCP粘包现象产生分析
  13. 莫烦theano学习自修第十天【保存神经网络及加载神经网络】
  14. SharePonit online 列表表单定制
  15. 使用 vue-cli-service inspect 来查看一个 Vue CLI 3 项目的 webpack 配置信息(包括:development、production)
  16. centos7 安装步骤
  17. Jmeter(二十八)Jmeter-Question之“HTTPS请求”
  18. kafka主题管理
  19. 算法笔记_201:第三届蓝桥杯软件类决赛真题(Java本科)
  20. php AES cbc模式 pkcs7 128位加密解密(微信小程序)

热门文章

  1. Serverless 每周小报-20190610
  2. Scheme实现数字电路仿真(3)——模块
  3. 软件工程实验一 Git代码版本管理
  4. AOP面试知识整理,^_^-包括spring Aop
  5. Maven项目中的packaging标签
  6. 使用CSS实现折叠面板总结
  7. 2019年最新老男孩高性能Web架构与自动化运维架构视频教程
  8. 关于独立部署web项目到tomcat服务器详情
  9. vue-cli脚手架目录(2.0)
  10. TLS/SSL 梳理