gpt4 book ai didi

c - 树元素未按正确顺序显示

转载 作者:太空宇宙 更新时间:2023-11-04 02:44:43 25 4
gpt4 key购买 nike

我正在尝试构建一个简单的树程序并以中序、前序和后序格式遍历它。我使用的代码是这样的:

#include <stdio.h>
#include <stdlib.h>

struct node
{
int info;
struct node* lchild;
struct node* rchild;
};
typedef struct node* NODE;

NODE getNode()
{
NODE temp;
temp = (NODE)malloc(sizeof(struct node));
return temp;
}

NODE insert(NODE root,int item)
{
NODE temp,prev,cur;
temp = getNode();
temp->info = item;
temp->lchild = NULL;
temp->rchild = NULL;
if(root==NULL)
{return temp;}
prev = NULL;
cur = root;
while(cur!=NULL)
{
prev = cur;
if(item<cur->info)
{
cur = cur->lchild;
}
else if(item>cur->info)
{
cur = cur->rchild;
}
}
if(item<prev->info)
{
prev->lchild = temp;
}
else if(item>prev->info)
{
prev->rchild = temp;
}
return root;
}

void inorderTraversal(NODE root)
{
if(root!=NULL)
{
inorderTraversal(root->lchild);
printf("%d\t",root->info);
inorderTraversal(root->rchild);
}
else
{
return;
}
}

void preorderTraversal(NODE root)
{
if(root!=NULL)
{
printf("%d\t",root->info);
preorderTraversal(root->lchild);
preorderTraversal(root->rchild);
}
else
{
return;
}
}

void postorderTraversal(NODE root)
{
if(root!=NULL)
{
postorderTraversal(root->lchild);
postorderTraversal(root->rchild);
printf("%d\t",root->info);
}
else
{
return;
}
}





int main() {

NODE root;
root = getNode();
root = NULL;
root = insert(root,10);
root = insert(root,20);
root = insert(root,15);
printf("Root is: %d\n",root->info);
printf("Inorder Traversal is :");
inorderTraversal(root);
printf("\n");
printf("Preorder traversal is :");
preorderTraversal(root);
printf("\n");
printf("Postorder traversal is :");
postorderTraversal(root);
printf("\n");
return 0;
}

我得到的输出是这样的:

根是:10中序遍历为:10 15 20
前序遍历为:10 20 15
后序遍历为:15 20 10

即10 被指定为根,理想情况下它应该是 15,左边 10,右边 15。这里有什么错误,我该如何解决?

谢谢!

最佳答案

您最终得到的树结构如下所示

                    10
\
20
/
15

遍历顺序如下:按顺序:10 15 20预购:10 20 15后单:15 20 10

BST 确实保持左子树中的元素小于右子树中的元素的属性。但是,他们不做 self-balancing 像 AVL 或红黑树。

关于c - 树元素未按正确顺序显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28556390/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com