大家好,欢迎来到IT知识分享网。
最近学习了一下用数组建立二叉搜索树,感觉自己又提高了一点点,好高兴!
下面写个模板,功能是:
输入 n , 接下来输入 n 个数,建立二叉搜索树。
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std;
int arr[1000];
void set_down(int t,int a[1000]);
void print_tree(int t,int a[1000]);//xian xu
int main()
{
int n,i;
scanf("%d",&n);
memset(arr,-1,sizeof(arr));
int x;
for(i=1; i<=n; i++)
{
scanf("%d",&x);
set_down(x,arr);
}
print_tree(1,arr);
}
void set_down(int t,int a[1000])
{
int n = 1;
while(a[n] != -1)
{
if(t < a[n])
n = n*2;
else
n = n*2+1;
}
a[n] = t;
}
void print_tree(int t,int a[1000]) // xian xu
{
printf("%d ",a[t]);
if(a[t*2] != -1)
print_tree(t*2,a);
if(a[t*2+1] != -1)
print_tree(t*2+1,a);
}
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/14422.html