#include"stdio.h"
typedef struct tree
{
int date;
struct tree *lchild;
struct tree *rchild;
}tree;
void createtree(tree *&t)
{
int num;
scanf("%d",&num);
if(num==0)
t=NULL;
else
{
t=new tree;
t->date=num;
createtree(t->lchild);
createtree(t->rchild);
}
}
void midprintf(tree *t)
{
if(t==NULL)
;
else
{ midprintf(t->lchild);
printf("%d\t",t->date);
midprintf(t->rchild );
}
}
int main()
{
tree *t=NULL;
printf("请输入整数\n");
createtree(t);
midprintf(t);
}
为什么这个二叉树不能中序输出,子函数中的取址符怎么理解址传递
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- SmallAntJ 2022-01-31 00:46关注
tree* &t; 是C++的语法,这里形参是一个tree指针的引用。把tree*看作数据类型,&t就是实参t的引用。void createtree(tree *&t) 意思是把实参t的引用传入函数中,对引用操作就是对原变量操作。可以参看这篇文章:https://zhuanlan.zhihu.com/p/139543762
类似的,如果用void createtree(tree **t)也可以实现,形参是tree指针的指针,可能方便你理解。
#include"stdio.h" typedef struct tree { int date; struct tree *lchild; struct tree *rchild; }tree; void createtree(tree **t) { int num; scanf("%d",&num); if(num==0) *t=NULL; else { *t=new tree; (*t)->date=num; createtree(&((*t)->lchild)); createtree(&((*t)->rchild)); } } void midprintf(tree *t) { if(t==NULL) ; else { midprintf(t->lchild); printf("%d\t",t->date); midprintf(t->rchild ); } } int main() { tree *t=NULL; printf("请输入整数\n"); createtree(&t); midprintf(t); }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 C++ yoloV5改写遇到的问题
- ¥20 win11修改中文用户名路径
- ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
- ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
- ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
- ¥15 帮我写一个c++工程
- ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
- ¥15 关于smbclient 库的使用
- ¥15 微信小程序协议怎么写
- ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?