zwh618618 2022-11-09 15:08 采纳率: 0%
浏览 8

我想用两个队列层序建立二叉树 但是直接无法运行

我想用两个队列层序建立二叉树 但是直接无法运行

class MyBinaryTreeNode{
public:
    typedef struct BiTNode{
        char data;
        struct BiTNode*leftchild,*rightchild;
    }BiTNode;
BiTNode* BuildBiT(string x){
    BiTNode *T = new BiTNode();
    queue<char>qd;
    queue<BiTNode*>qT;
    qT.push(T);
    int length = sizeof x / sizeof (x[1]) ;
    int numbers = 1;
    for(int i = 0;i<length;i++){
        qd.push(x[0]);
    }
    while(qd.size()!=0) {
        if (numbers + 1 < length) {
            if (qd.front() == '#') {
                qd.pop();
                qT.front() = NULL;
                qT.pop();
            } else {
                qT.front()->data = qd.front();
                qd.pop();
                BiTNode *a = (BiTNode *) malloc(sizeof(BiTNode *));
                qT.front()->leftchild = a;
                BiTNode *b = (BiTNode *) malloc(sizeof(BiTNode *));
                qT.front()->rightchild = b;
                qT.pop();
                numbers += 2;
            }
        }
        else if (numbers + 1 == length) {
            if (qd.front() == '#') {
                qd.pop();
                qT.front() = NULL;
                qT.pop();
            }
            else {
                qT.front()->data = qd.front();
                qd.pop();
                BiTNode *a = (BiTNode *) malloc(sizeof(BiTNode *));
                qT.front()->leftchild = a;
                qT.push(qT.front()->leftchild);
                qT.pop();
                numbers++;
            }
        }
        else {
            if (qd.front() == '#') {
                qd.pop();
                qT.front() = NULL;
                qT.pop();
            } else {
                qT.front()->data = qd.front();
                qd.pop();
                qT.pop();
            }
        }
    }
        return T;
}
};


img

我的解答思路和尝试过的方法
想知道哪里错了
  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2022-11-09 18:02
    关注
    评论

报告相同问题?

问题事件

  • 创建了问题 11月9日

悬赏问题

  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥15 clion的参数提示怎么关闭
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀
  • ¥15 mifare plus卡认证