如何解决访问树中的右节点指针参考指针时出错
在 void po() 函数中解决如何将二叉树转换为双向链表树的问题,我们传递根节点和 2 个节点作为它们的地址,现在我想设置引用之一的右侧节点我正在做下面的方式并得到错误任何人都知道如何解决这个问题???
void po(Node* root,Node **p,Node**q){
if(p==NULL)
return;
po(root->left,p,q);
if(*p==NULL){
*p=root;
*q=root;
}
else{
*(q)->right=root; // This line contain error !!!
root->left=*q;
*q=root;
}
po(root->right,q);
}
Node * bToDLL(Node *root)
{
if(root==NULL )
return root;
Node* a=NULL;
Node* b=NULL;
po(root,&a,&b);
return a;
}
错误:- 错误:请求 * q 中的成员权限,它是指针类型 Node*(也许您打算使用 -> ?) *(q)->右=根; ^
解决方法
本声明
*(q)->right=root;
其实很像
*(q->right) = root;
因为后缀运算符 -> 相对于一元运算符 * 具有更高的优先级。
但是 q
是指向指针的指针。所以指向的指针没有数据成员right
。
你的意思是
( *q )->right = root;
在这种情况下,表达式 *q
指向一个结构类型的对象。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。