gpt4 book ai didi

c - 每次左子树遍历打印出 '0',每次右子树遍历打印出 '1'

转载 作者:行者123 更新时间:2023-11-30 19:19:12 26 4
gpt4 key购买 nike

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>
#define n 5

struct node
{
int num;
struct node *left;
struct node *right;
}*root_ptr, *current, *previous, *newNode;

void getCodes(struct node *);

char *symbols[] = {"A", "B", "C", "D", "E"}, **p=symbols;
char codeKeeper[32]={0}, *code_ptr = codeKeeper;

int main(int argc, char *argv[])
{
//some code

//tree structure formation
getCodes(root_ptr);
return 0;
}
void getCodes(struct node *no)
{
if(no!=NULL)
{
*code_ptr++ = '0';
getCodes(no->left);
if(no->left==NULL)
printf("%d left child is %s having code as %s0\n", no->num, *p++, codeKeeper+1);
if(no->right==NULL)
printf("%d right child is %s having code as %s1\n", no->num, *p++, codeKeeper+1);
*(--code_ptr) = '1';
getCodes(no->right);
}
}

形成的树是

            2
1 3
4

我想要做的是为每个左分支遍历打印“0”,为每个右分支遍历打印“1”,所以我使用了中序遍历。另外,当我以中序方式遍历时,它必须检查每个节点是否没有左子树或右子树或两者,并相应地从左到右打印出符号(附加0和1),并填充空指针遇到过。

我的getCodes()函数只能从右边打印出2个字符..上面的树深度及其代码被吃掉或没有填充。

编辑:符号“A”必须是 1 的左子节点,符号“B”必须是 1 的右子节点..像这样,必须在遍历时动态识别树叶

最终的树可以被认为是

               2
1 3
A B C 4
D E

因此,A 需要输出 00,B 需要输出 01,C 需要输出 10,D 需要输出 110,E 需要输出 111从上面的树的外观..您可以看到 A、B、C、D、E 已为叶子中的每个 NULL 指针从左到右线性排列

这是我从 getCodes() 函数中得到的结果

1 left child is A having code as 00
1 right child is B having code as 01
3 left child is C having code as 10
4 left child is D having code as 10
4 right child is E having code as 11

最佳答案

void inorder(char string[20],int index,tree *root)//index is sent 0 from main
{
if(root)
{
string[index]='0';
string[index+1]='\0';
inorder(string,index+1,root->left);//Add 0 at end when you go to left
printf("%s\n",string);
string[index]='1';
string[index]='\0';
inorder(string,index+1,root->right);//Add 1 at end when you go to right
}
}

关于c - 每次左子树遍历打印出 '0',每次右子树遍历打印出 '1',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25132922/

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