西皮呦 2022-03-09 18:50 采纳率: 83.3%
浏览 63
已结题

线索二叉树 线索化函数的参数bt前为什么不加引用&?

ThrBiTree(ThrBiNode* bt,ThrBiNode* &pre),bt指向当前结点,pre指向bt的前一个结点,pre本身就是指针变量要加个引用是为了修改他,那bt也是要修改的啊为什么不加引用?

具体实现如下:

struct ThrBiNode{//结构体定义

char data;

ThrBiNode *lchild,*rchild;

int ltag,rtag;

} * pre;

void InThrBiTree::ThrBiTree(ThrBiNode* bt,ThrBiNode* &pre){//线索化

if(bt!=NULL){

ThrBiTree(bt->lchild,pre);

if(bt->lchild==NULL){//处理左边

bt->lchild=pre;

bt->ltag=1;

}

if(bt->rchild==NULL){//处理右边

bt->rtag=1;

}

if(pre&&pre->rtag){//处理前驱的后继

pre->rchild=bt;

}

pre=bt;//指针后移

ThrBiTree(bt->rchild,pre);

}

}

  • 写回答

1条回答 默认 最新

  • 真相重于对错 2022-03-09 18:57
    关注

    不用修改它,他是个输入参数,所以不用

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月22日
  • 已采纳回答 3月14日
  • 创建了问题 3月9日