首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >序遍历迭代法

序遍历迭代法
EN

Stack Overflow用户
提问于 2021-02-13 22:51:53
回答 1查看 29关注 0票数 0

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

代码语言:javascript
复制
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;
        }
    }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-13 23:36:37

错误出现在while-条件中。想想看:当while条件为true时,下一个if条件也为true,因此您永远不会进入else块。

您应该退出循环的唯一时间是在命中此break

代码语言:javascript
复制
if(top==0) {
    break;
}

因此,通过将您的while转换为:

代码语言:javascript
复制
while(true) {
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66186417

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档