04-树8. Complete Binary Search Tree (30)

时间限制
100 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue

A Binary Search Tree (BST) is recursively defined as a binary tree which has the following properties:

  • The left subtree of a node contains only nodes with keys less than the node's key.
  • The right subtree of a node contains only nodes with keys greater than or equal to the node's key.
  • Both the left and right subtrees must also be binary search trees.

A Complete Binary Tree (CBT) is a tree that is completely filled, with the possible exception of the bottom level, which is filled from left to right.

Now given a sequence of distinct non-negative integer keys, a unique BST can be constructed if it is required that the tree must also be a CBT. You are supposed to output the level order traversal sequence of this BST.

Input Specification:

Each input file contains one test case. For each case, the first line contains a positive integer N (<=1000). Then N distinct non-negative integer keys are given in the next line. All the numbers in a line are separated by a space and are no greater than 2000.

Output Specification:

For each test case, print in one line the level order traversal sequence of the corresponding complete binary search 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.

Sample Input:

10
1 2 3 4 5 6 7 8 9 0

Sample Output:

6 3 8 1 5 7 9 0 2 4

提交代码

解法一:

数组做法:

 #include<cstdio>
#include<algorithm>
#include<iostream>
#include<cstring>
#include<queue>
#include<vector>
#include<cmath>
#include<string>
using namespace std;
int tree[],endtree[];
int GetLeftLength(int n){
int h=log(n+)/log();//除去最后一排的元素
int x=n+-pow(,h);
if(x>=pow(,h-)){
x=pow(,h-);
}
return x+pow(,h-)-;
}
void solve(int left,int right,int root){
int n=right-left+;
if(!n) return;
int l=GetLeftLength(n);
endtree[root]=tree[left+l];
solve(left,left+l-,root*+);
solve(left+l+,right,root*+);
}
int main(){
//freopen("D:\\INPUT.txt","r",stdin);
int n;
scanf("%d",&n);
int i;
for(i=;i<n;i++){
scanf("%d",&tree[i]);
}
sort(tree,tree+n);
solve(,n-,);
printf("%d",endtree[]);
for(i=;i<n;i++){
printf(" %d",endtree[i]);
}
printf("\n");
return ;
}

方法二:

链表做法:

递归建树的思想:想找出当前的中间大的树,作为当前树根,然后遍历左子树,右子树,最后对所建的BST进行层序遍历。

当前元素总个数为n,则层数k为ceil(log2(n+1)):

1.n>=3*2^(k-2),即查找树的最后一个元素位于根的右子树部分。则此时右子树有 n-(3*2^(k-2)-1)+2^(k-2)-1 个元素,左边有 n-右子树元素个数-1=n-(n-(3*2^(k-2)-1)+2^(k-2)-1)-1=2^(k-1)-1个元素,则中间元素下标为 2^(k-1)-1 (从0开始)。

2.n<3*2^(k-2),即查找树的最后一个元素位于根的左子树部分。则此时右子树有 2^(k-2)-1 个元素,左边有 n-右子树元素个数-1=n-(2^(k-2)-1)-1=n-2^(k-2) 个元素,则中间元素下标为 n-2^(k-2) (从0开始)。

 #include<cstdio>
#include<functional>
#include<queue>
#include<cmath>
#include<algorithm>
#include<iostream>
using namespace std;
int mem[];
struct node{
int v;
node *l,*r;
node(){
l=r=NULL;
}
};
void CBTBuild(int *mem,int n,int mid,node *&p){
//q.push(mem[mid]);
p=new node();
p->v=mem[mid];
//cout<<mem[mid]<<endl; if(mid->=){//left tree
int nn=mid;
int k=ceil(log(nn+)/log());
if(nn>=*pow(,k-)){//超过一半
CBTBuild(mem,nn,pow(,k-)-,p->l);
}
else{//未超过一半
CBTBuild(mem,nn,nn-pow(,k-),p->l);
}
}
if(mid+<n){//right tree
int nn=n-(mid+);
int k=ceil(log(nn+)/log());
if(nn>=*pow(,k-)){//超过一半
CBTBuild(mem+mid+,nn,pow(,k-)-,p->r);
}
else{//未超过一半
CBTBuild(mem+mid+,nn,nn-pow(,k-),p->r);
}
}
}
int main(){
//freopen("D:\\INPUT.txt","r",stdin);
int n,i,j,k;
queue<node> q;
scanf("%d",&n);
for(i=;i<n;i++){
scanf("%d",&mem[i]);
}
sort(mem,mem+n); /*for(i=0;i<n;i++){
cout<<mem[i]<<endl;
}*/
node *h;
k=ceil(log(n+)/log());
if(n>=*pow(,k-)){//超过一半
CBTBuild(mem,n,pow(,k-)-,h); //cout<<mem[int(pow(2,k-1)-1)]<<endl; }
else{//未超过一半
CBTBuild(mem,n,n-pow(,k-),h); //cout<<mem[int(n-pow(2,k-2))]<<endl; }
int top;
node p=*h;
q.push(p);
printf("%d",p.v);
while(!q.empty()){
p=q.front();
q.pop();
if(p.l!=NULL){
q.push(*(p.l));
printf(" %d",p.l->v);
}
if(p.r!=NULL){
q.push(*(p.r));
printf(" %d",p.r->v);
}
}
printf("\n");
return ;
}

pat04-树8. Complete Binary Search Tree (30)的更多相关文章

  1. PAT题库-1064. Complete Binary Search Tree (30)

    1064. Complete Binary Search Tree (30) 时间限制 100 ms 内存限制 32000 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHE ...

  2. PAT 甲级 1064 Complete Binary Search Tree (30 分)(不会做,重点复习,模拟中序遍历)

    1064 Complete Binary Search Tree (30 分)   A Binary Search Tree (BST) is recursively defined as a bin ...

  3. PAT甲级:1064 Complete Binary Search Tree (30分)

    PAT甲级:1064 Complete Binary Search Tree (30分) 题干 A Binary Search Tree (BST) is recursively defined as ...

  4. pat1064. Complete Binary Search Tree (30)

    1064. Complete Binary Search Tree (30) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHE ...

  5. pat 甲级 1064. Complete Binary Search Tree (30)

    1064. Complete Binary Search Tree (30) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHE ...

  6. PTA 04-树6 Complete Binary Search Tree (30分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/669 5-7 Complete Binary Search Tree   (30分) A ...

  7. 1064. Complete Binary Search Tree (30)【二叉树】——PAT (Advanced Level) Practise

    题目信息 1064. Complete Binary Search Tree (30) 时间限制100 ms 内存限制65536 kB 代码长度限制16000 B A Binary Search Tr ...

  8. PAT Advanced 1064 Complete Binary Search Tree (30) [⼆叉查找树BST]

    题目 A Binary Search Tree (BST) is recursively defined as a binary tree which has the following proper ...

  9. 1064 Complete Binary Search Tree (30分)(已知中序输出层序遍历)

    A Binary Search Tree (BST) is recursively defined as a binary tree which has the following propertie ...

随机推荐

  1. JS万金油的类型判断方法

    Object.prototype.toString.call(data).slice(8, -1).toLowerCase();

  2. ubuntu - 安装hive

    粗略步骤: 详细参考:https://www.2cto.com/net/201804/735478.html 环境:ubunut  jdk  hadoop   mysql 一.下载hive 二.解压( ...

  3. C#静态类 转载:(原文:http://www.cnblogs.com/chenlulouis/ )

    静态类是不能实例化的,我们直接使用它的属性与方法,静态类最大的特点就是共享. 探究 public static class StaticTestClass{    public static int ...

  4. springcloud系列11 整合微服务网关zuul

    这个模块是一个独立的模块所以需要建立一个模块, 首先引入: 依赖pom.xml <?xml version="1.0" encoding="UTF-8"? ...

  5. Qt 学习之路 2(17):文件对话框

    Home / Qt 学习之路 2 / Qt 学习之路 2(17):文件对话框 Qt 学习之路 2(17):文件对话框  豆子  2012年9月24日  Qt 学习之路 2  85条评论 在前面的章节中 ...

  6. 2-28 switch

  7. Python的安装位置与Python库

    如何查看Python的安装位置: 输入 where python ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...

  8. P4213 【模板】杜教筛

    [题目链接] https://www.luogu.org/problemnew/show/P4213 给定一个正整数\(N(N\le2^{31}-1)\) 求 \(ans_1=\sum_{i=1}^n ...

  9. CodeForces - 593A -2Char(思维+暴力枚举)

    Andrew often reads articles in his favorite magazine 2Char. The main feature of these articles is th ...

  10. P5020 货币系统 (NOIP2018)

    传送门 BFS解法 显然如果一个面额A可以被其他面额表示出来 那么这个面额A就没用了 且如果A不能被其他面额表示,那么A一定有用(A本身的值只有自己可以表示) 发现面额最大不超过 25000 那么设 ...