题目:
data:image/s3,"s3://crabby-images/a2120/a2120bdc7a194536edc9c314057eb759dbe76048" alt=""
typedef struct node{
char data;
node *left;
node *right;
}BTree;
void inorder(BTree tree,int storey){ //tree是结点,storey是当前层数,最高是0
BTree p = tree;
if( p.left!= nullptr || p.right!= nullptr ){ //左右孩子不全为空
if(storey !=0){printf("%s","(");} //不是最外层就套上括号
if(p.left!= nullptr){ //左孩子不为空的话,先遍历左孩子
inorder(*p.left,storey+1); //层数+1
}
}
printf("%c",p.data); //输出根结点内容
if(p.left!= nullptr || p.right!= nullptr) { //左右孩子不全为空
if (p.right != nullptr) { //右孩子不为空的话,遍历右孩子
inorder(*p.right, storey + 1); //层数+1
}
if (storey != 0) { //不是最外层就套上括号
printf("%s", ")");
}
}
}
运行效果:
data:image/s3,"s3://crabby-images/ab01d/ab01d17d18430c6874b12f4dfa3b36140ec03adc" alt=""
data:image/s3,"s3://crabby-images/bbf8f/bbf8f55436c263b1cfb6ced681618d6a452242ee" alt=""
?
|