【问题标题】:Inorder Traversal Iterative Method中序遍历迭代法
【发布时间】:2021-05-17 01:32:15
【问题描述】:

这是我的迭代中序遍历代码。它根本没有给我输出,它所做的只是给我一个空白屏幕。如果有人可以检查我的代码并告诉我我在哪里犯了错误,那将非常有帮助。

void iterativeInorder(struct node *root) {
    if(root==NULL) {
        return;
    }
    struct node *stack[100];
    int top=0;
    while(root) {
        if(root!=NULL) {
            stack[top++]=root;
            root=root->left;
        }
        else {
            if(top==0) {
                break;
            }
            root=stack[--top];
            printf("%d ", root->data);
            root=root->right;
        }
    }
}

【问题讨论】:

  • 您应该添加一个标签来指定此代码所在的语言。
  • @trincot 是的,我错过了。我的错。

标签: c linked-list tree stack inorder


【解决方案1】:

错误在while条件中。想一想:当 while 条件为真时,下一个 if 条件也为真,所以你永远不会进入 else 块。

你应该退出循环的唯一一次是当你点击这个break

if(top==0) {
    break;
}

因此,将您的 while 转换为:

while(true) {

【讨论】:

  • 非常感谢。它现在工作正常,我明白为什么它没有给我任何输出。
猜你喜欢
  • 1970-01-01
  • 2021-10-30
  • 2011-08-31
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-05-10
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多