|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
主要是不理解堆栈的作用,结点进栈退栈。
- //二叉树根结点为T
- //请利用二叉树遍历的非递归算法写出求二叉树中由指针q所指结点(设q所指
- //结点不是二叉树的根结点)的兄弟结点的算法
- // 若二叉树中存在该兄弟结点,算法给出该兄弟结点的位置
- //否则算法给出NULL
- //算法核心思想:
- //利用二叉树的前序遍历的非递归算法解决该问题。
- //在遍历过程中,当访问一个结点时,判断该结点的左孩子或右孩子是否时q指结点,若是,返回该结点的左孩子或者右孩子的位置即可
- BTREE FINDBROTHER(BTREE T,BTREE q)
- {
- //T 为二叉树根结点所在链结点的地址
- BTREE STACK[M],p =T;
- int top = -1;
- do
- {
- while (p != NULL)
- {
- if(p -> lchild == q)
- {return p->rchild;
- }
- if(p->rchild==q)
- {return p->lchild;//访问当前p指的结点
- }
- STACK[++top] = p;//当前p指的结点的地址进栈
- p = p->lchild; //将p移动其左孩子结点
- }
- p = STACK[top--]; //退栈
- p = p->rchild; //将p移动到其右孩子结点
- } while(p != NULL||top!=-1);
- }
复制代码 |
|