quyuq04301991 2015-01-18 04:19 采纳率: 100%
浏览 2267
已采纳

C++语言如何用数组实现一个二叉树?

提示,二叉树的第n层可以用数组的第2^(n-1)~2^n-1表示。定义一个二叉树,并且实现对它的遍历。

  • 写回答

1条回答 默认 最新

  • threenewbee 2015-01-18 05:42
    关注
     struct node
    {
        int l,r;
    };
    struct node tree[100];
    int path[100];
    int ans;
    void init()
    {
        int i;
        ans = 0;
        for(i = 0 ; i < 100 ; i ++  )
            tree[i].l = tree[i].r = -1,path[i] = -1;
    }
    void preOrderTree(int root)
    {
        if(root == -1 )
            return ;
        path[ans++] = root;
        preOrderTree(tree[root].l);
    
        preOrderTree(tree[root].r);
    
    }
    int main()
    {
        int T,i,n;
        int root,a,b,c;
        scanf("%d",&T);
        while(T--)
        {
            init();
            scanf("%d",&n);
            scanf("%d",&root);
            for(i = 0 ; i < n -1; i ++)
            {
                scanf("%d%d%d",&a,&b,&c);
                if(c == 0)
                {
                    tree[a].l = b;
                }
                else
                {
                    tree[a].r = b;
                }
            }
            preOrderTree(root);
            for(i = 0 ; i < n ; i ++)
                printf("%d%c",path[i],i' ':'/n');
    
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog