NaiveGato 2016-11-20 12:47 采纳率: 0%
浏览 1121

【C++二叉搜索树】采用STL实现广度遍历时遇见的问题

首先是二叉树结点类型定义

 typedef struct node {
    ElemType data;
    struct node* lchild;
    struct node* rchild;
}*BST,BSTree;

此为一开始的广度遍历代码:

 void Level(BST root)
{
    queue<BSTree> Q;
    BST temp;
    if (!root)
        return;
    Q.push(*root);
    while (Q.size()>0)
    {
        temp = &(Q.front());
        Q.pop();
        cout << temp->data;
        if (temp->lchild)
            Q.push(*(temp->lchild));
        if (temp->rchild)
            Q.push(*(temp->rchild));
    }
}

遍历结果总是缺少子树或者重复包含,后改为以下代码:

正常打印

void Level(BST root)
{
    queue<BSTree> Q;
    BST temp;
    BSTree P;
    if (!root)
        return;
    Q.push(*root);
    while (Q.size()>0)
    {
        P = Q.front();
        temp = &P;
        Q.pop();
        cout << temp->data;
        if (temp->lchild)
            Q.push(*(temp->lchild));
        if (temp->rchild)
            Q.push(*(temp->rchild));
    }
} 

怀疑问题出在#include中的pop()函数,求解答,Orz。

  • 写回答

2条回答 默认 最新

  • devmiao 2016-11-20 12:48
    关注
    评论

报告相同问题?

悬赏问题

  • ¥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
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题