如何修复以下代码以进行二叉树级别订单打印
How to fix below code for binary tree level order printing
>我已经实现了以下代码,用于二叉树中节点的级别顺序打印。但是,当节点同时具有左子节点和右子节点时,它将失败。
例如,下面是我的二叉树。
1
2
5
/
3 6
4
预期输出为:1 2 5 3 6 4 但是,我的代码打印:1 2 5 3 4 4
我犯了什么错误?感觉像是一些指针上的傻瓜。
以下是我编写的函数:
void printNodes(Node *arr[], int numOfNodes)
{
Node *outputArr[]={NULL};
int j=0;
for(int i=0; i<numOfNodes; i++)
{
printf("%d ",arr[i]->data);
if(arr[i]->left!=NULL)
{
outputArr[j++]=arr[i]->left;
}
if(arr[i]->right!=NULL)
{
outputArr[j++]=arr[i]->right;
}
}
if(j>0)
printNodes(outputArr, j);
else
return;
}
void levelOrder(Node * root) {
Node *list[]={NULL};
int ctr=0;
if(root == NULL)
return;
printf("%d ",root->data);
if(root->left != NULL)
list[ctr++]=root->left;
if(root->right != NULL)
list[ctr++]=root->right;
printNodes(list, ctr);
}
我将粘贴一些驱动程序代码:
main() {
Example myTree;
Node* root = NULL;
int t;
int data;
std::cin >> t;
while(t-- > 0) {
std::cin >> data;
root = myTree.insert(root, data);
}
myTree.levelOrder(root);
return 0;
}
假设您出于某种原因(教育或其他原因(正在做您正在做的事情,只是对其进行最低限度的修改以执行我认为您希望您的方法做的事情,请尝试以下操作:
void printNodes(std::vector<Node*> list) {
std::vector<Node*> newList;
for(int i=0; i<list.size(); i++) {
printf("%d ",list[i]->data);
if(list[i]->left) newList.push_back(list[i]->left);
if(list[i]->right) newList.push_back(list[i]->right);
}
if(!newList.empty()) printNodes(newList);
else return;
}
void levelOrder(Node * root) {
if(!root) return;
std::vector<Node*> list;
printf("%d ",root->data);
if(root->left) list.push_back(root.left);
if(root->right) list.push_back(root.right);;
printNodes(list);
}
更好的解决方案可能是根本不使用递归,而是执行通常的广度第一遍历 IMO。
相关文章:
- 如何循环打印顶点结构
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 如何在c++中打印目录
- 有一个打印语句的函数是一种糟糕的编程实践吗
- 在线编译器中的分段C++没有打印消息
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 如何将结构插入到集合中并打印集合的成员
- 在循环C++中指定字符串之后,不会打印该字符串
- 以螺旋方式打印矩阵的程序.(工作不好)
- 从控制台中删除最后打印的元素
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 如何仅使用对象名称打印特定于对象的成员
- 回溯C++不打印函数,因此文件
- 在一定长度后从数组中打印时缺少整数
- 为什么这个 c++ 代码打印出长度 5,当我打印出字符串时,程序会自动终止?
- 在gem5中打印文件中的所有cache_blocks
- 打印数字图案
- Log4cpp:以UTC/GMT时区打印日期
- 如何使用gdb制作一个可以漂亮地打印每个对象的C++函数