数组建立二叉搜索树

数组建立二叉搜索树最近学习了一下用数组建立二叉搜索树,感觉自己又提高了一点点,好高兴!下面写个模板,功能是:输入n,接下来输入n个数,建立二叉搜索树。#includeiostream#includealgorithm#includecstdio#includecstdlib#includecstringusingnamespacestd;intarr[100

大家好,欢迎来到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

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信