题目1467:二叉排序树
来源:互联网 发布:湘阴县知源中学 编辑:程序博客网 时间:2024/05/16 18:14
- 题目描述:
二叉排序树,也称为二叉查找树。可以是一颗空树,也可以是一颗具有如下特性的非空二叉树:
1. 若左子树非空,则左子树上所有节点关键字值均不大于根节点的关键字值;
2. 若右子树非空,则右子树上所有节点关键字值均不小于根节点的关键字值;
3. 左、右子树本身也是一颗二叉排序树。
现在给你N个关键字值各不相同的节点,要求你按顺序插入一个初始为空树的二叉排序树中,每次插入后成功后,求相应的父亲节点的关键字值,如果没有父亲节点,则输出-1。
- 输入:
输入包含多组测试数据,每组测试数据两行。
第一行,一个数字N(N<=100),表示待插入的节点数。
第二行,N个互不相同的正整数,表示要顺序插入节点的关键字值,这些值不超过10^8。
- 输出:
输出共N行,每次插入节点后,该节点对应的父亲节点的关键字值。
- 样例输入:
52 5 1 3 4
- 样例输出:
-12253
#include<iostream>#include<set>#include<stdio.h>#include<string.h>using namespace std; struct node{ node *left,*right; int n;}; void creat(node *&p,int n){ node *root=p; node *pr; if(root==NULL) { p=new node; p->n=n; p->left=p->right=NULL; cout<<-1<<"\n"; } else { //pr=p; while(root) { pr=root; if(root->n<n) root=root->right; else root=root->left; } root=new node; root->left=root->right=NULL; root->n=n; if(pr->n<root->n) pr->right=root; else pr->left=root; cout<<pr->n<<"\n"; }}int main(){ int n; while(cin>>n) { int a; node *p=NULL; for(int i=0;i<n;i++) { cin>>a; creat(p,a); } }}
- 题目1467:二叉排序树
- 题目1467:二叉排序树
- 题目1467:二叉排序树
- 题目1467:二叉排序树
- 题目1467:二叉排序树
- 九度 题目1467:二叉排序树
- 题目1467:二叉排序树 九度OJ
- 九度oj 题目1467:二叉排序树
- (题目35)题目1201:二叉排序树
- 题目35:二叉排序树
- 题目1104: 二叉排序树
- 题目1201:二叉排序树
- 题目1201:二叉排序树
- 题目1201:二叉排序树
- 题目1201:二叉排序树
- 题目1201:二叉排序树
- 题目1201:二叉排序树
- Jobdu 题目1201:二叉排序树
- google map api key申请
- 函数传递的参数是原参数的副本
- vim相关命令
- c++对象和内存
- 记录学习旅途中的问题 ——AUTOCAD
- 题目1467:二叉排序树
- iOS 7开发之NSURLSession vs NSURLConnection
- SQL Server 2005事务隔离级别与性能
- mysql相关命令
- Python编程中常用的12种基础知识总结
- 为VC++ 6.0 配置OpenGL 环境 [图形学]
- C++虚函数的实现机制
- 区间最值与线段树
- 把“苹果中国首发”视为扬眉吐气是自卑的表现