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 单纯型python实现编译报错
  • ¥15 c++2013读写oracle
  • ¥15 c++ gmssl sm2验签demo
  • ¥15 关于模的完全剩余系(关键词-数学方法)
  • ¥15 有没有人懂这个博图程序怎么写,还要跟SFB连接,真的不会,求帮助
  • ¥15 PVE8.2.7无法成功使用a5000的vGPU,什么原因
  • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
  • ¥15 安装quartus II18.1时弹出此error,怎么解决?
  • ¥15 keil官网下载psn序列号在哪
  • ¥15 想用adb命令做一个通话软件,播放录音