1123 Is It a Complete AVL Tree(30 分)
An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child subtrees of any node differ by at most one; if at any time they differ by more than one, rebalancing is done to restore this property. Figures 1-4 illustrate the rotation rules.
![]() |
![]() |
|---|---|
![]() |
![]() |
Now given a sequence of insertions, you are supposed to output the level-order traversal sequence of the resulting AVL tree, and to tell if it is a complete binary tree.
Input Specification:
Each input file contains one test case. For each case, the first line contains a positive integer N (≤ 20). Then N distinct integer keys are given in the next line. All the numbers in a line are separated by a space.
Output Specification:
For each test case, insert the keys one by one into an initially empty AVL tree. Then first print in a line the level-order traversal sequence of the resulting AVL tree. All the numbers in a line must be separated by a space, and there must be no extra space at the end of the line. Then in the next line, print YES if the tree is complete, or NO if not.
Sample Input 1:
5
88 70 61 63 65
Sample Output 1:
70 63 88 61 65
YES
Sample Input 2:
8
88 70 61 96 120 90 65 68
Sample Output 2:
88 65 96 61 70 90 120 68
NO
又是一道avl tree的题,好久不用纯c了,一直用c++,用纯c写一发,不画图写不出来。。。

代码:
#include <stdio.h>
#include <stdlib.h>
typedef struct tree tree;
struct tree {
int data;
tree *left,*right;
}*head = NULL;
int n,d,flag = ;
int level[];
tree *create(int data) {///创建节点
tree *t = (tree *)malloc(sizeof(tree));
t -> left = t -> right = NULL;
t -> data = data;
return t;
}
int max_(int a,int b) {///最大值
return a > b ? a : b;
}
int getheight(tree *t) {///求高度
if(t == NULL)return ;
return max_(getheight(t -> left),getheight(t -> right)) + ;
}
tree *ll(tree *t) {///左左旋
tree *temp = t -> left;
t -> left = temp -> right;
temp -> right = t;
return temp;
}
tree *rr(tree *t) {///右右旋
tree *temp = t -> right;
t -> right = temp -> left;
temp -> left = t;
return temp;
}
tree *lr(tree *t) {///左右旋
t -> left = rr(t -> left);
return ll(t);
}
tree *rl(tree *t) {///右左旋
t -> right = ll(t -> right);
return rr(t);
}
tree *insert_(tree *t,int data) {
if(t == NULL)return create(data);
else if(data > t -> data)t -> right = insert_(t -> right,data);
else t -> left = insert_(t -> left,data);
int a = getheight(t -> left),b = getheight(t -> right);
if(a - b == ) {///左边高
if(data > t -> left -> data) {///插入的结点 在左子树的右子树
t = lr(t);
}
else t = ll(t);///在左子树的左子树
}
else if(b - a == ) {
if(data < t -> right -> data) {///插入的结点 在右子树的左子树
t = rl(t);
}
else t = rr(t);///在右子树的右子树
}
return t;
}
void level_order(tree *t) {///判断是否是完全二叉树
tree *q[] = {t},*p;
int l = ,r = ;
while(l < r) {
p = q[l ++];
level[l - ] = p -> data;
if(p -> left) {
if(flag == )flag = ;///之前有空结点 那么肯定不是完全二叉树
q[r ++] = p -> left;
}
else if(flag == )flag = ;///遇到空结点
if(p -> right) {
if(flag == )flag = ;
q[r ++] = p -> right;
}
else if(flag == )flag = ;
}
}
int main() {
scanf("%d",&n);
for(int i = ;i < n;i ++) {
scanf("%d",&d);
head = insert_(head,d);
}
level_order(head);
for(int i = ;i < n;i ++) {
if(i)putchar(' ');
printf("%d",level[i]);
}
puts(flag ? "\nYES" : "\nNO");
}
1123 Is It a Complete AVL Tree(30 分)的更多相关文章
- 1123. Is It a Complete AVL Tree (30)
An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child sub ...
- PAT Advanced 1123 Is It a Complete AVL Tree (30) [AVL树]
题目 An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child ...
- PAT甲级题解-1123. Is It a Complete AVL Tree (30)-AVL树+满二叉树
博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6806292.html特别不喜欢那些随便转载别人的原创文章又不给 ...
- PAT 1123. Is It a Complete AVL Tree (30)
AVL树的插入,旋转. #include<map> #include<set> #include<ctime> #include<cmath> #inc ...
- 1123 Is It a Complete AVL Tree
1123 Is It a Complete AVL Tree(30 分) An AVL tree is a self-balancing binary search tree. In an AVL t ...
- PAT甲级1123. Is It a Complete AVL Tree
PAT甲级1123. Is It a Complete AVL Tree 题意: 在AVL树中,任何节点的两个子树的高度最多有一个;如果在任何时候它们不同于一个,则重新平衡来恢复此属性.图1-4说明了 ...
- PAT甲级——1123 Is It a Complete AVL Tree (完全AVL树的判断)
嫌排版乱的话可以移步我的CSDN:https://blog.csdn.net/weixin_44385565/article/details/89390802 An AVL tree is a sel ...
- PAT 1123 Is It a Complete AVL Tree
An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child sub ...
- PAT甲级1123 Is It a Complete AVL Tree【AVL树】
题目:https://pintia.cn/problem-sets/994805342720868352/problems/994805351302414336 题意: 给定n个树,依次插入一棵AVL ...
随机推荐
- 字符串== equals
经常碰到比较字符串的题, eg: public class StringDemo{ private static final String MESSAGE = "taobao"; ...
- Spark源码分析之八:Task运行(二)
在<Spark源码分析之七:Task运行(一)>一文中,我们详细叙述了Task运行的整体流程,最终Task被传输到Executor上,启动一个对应的TaskRunner线程,并且在线程池中 ...
- 如何将linux服务器作为文件服务器
在开发过程中想要使用linux服务器作为文件服务器,可以通过 IP+文件名来获取文件信息,比如http://localhost/banner/a.jpg.设置过程如下 1.安装apache2 sudo ...
- 【BZOJ3251】树上三角形 暴力
[BZOJ3251]树上三角形 Description 给定一大小为n的有点权树,每次询问一对点(u,v),问是否能在u到v的简单路径上取三个点权,以这三个权值为边长构成一个三角形.同时还支持单点修改 ...
- maven依赖本地非repository中的jar包【转】
今天在使用maven编译打包一个web应用的时候,碰到一个问题: 项目在开发是引入了依赖jar包,放在了WEB-INF/lib目录下,并通过buildpath中将web libariary导入. 在e ...
- Jeff Dean 排序时间计算
Quicksort (sometimes called partition-exchange sort) https://en.m.wikipedia.org/wiki/Quicksort
- AsyncHttpClien访问网络案例分析
Android数据存储的四种方式分别是:SharedPreferences存储.File文件存储.Network网络存储和sqlite数据库存储,网络存储需要使用AsyncHttpClient发送请求 ...
- Java图像处理最快技术:ImageJ 学习第一篇
ImageJ是世界上最快的纯Java的图像处理程序. 它能够过滤一个2048x2048的图像在0.1秒内(*). 这是每秒40万像素!ImageJ的扩展通过使用内置的文本编辑器和Java编译器的Ima ...
- 阿里云ecs docker使用(3)
进入docker后安装nodejs 1. 安装nodejs 2. 安装express-generator 3. mkdir repo && cd repo express myapp ...
- 【docker】kubernetes集群一键部署包
背景说明: 随着docker使用的逐步深入,docker的管理变得越来越麻烦,单纯的通过docker命令行的方式进行管理已经不能满足需求,同时也存在效率低下的问题.所以急需一个docker集群管理工具 ...



