锁定老帖子 主题:树的遍历
精华帖 (0) :: 良好帖 (0) :: 新手帖 (11) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-06-29
最后修改:2009-06-29
package dataStucture;
/**
package dataStucture;
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-08-18
期待楼主放出后序遍历的非递归
|
|
返回顶楼 | |
发表时间:2009-08-26
50 def left?() 51 @left != nil 52 end 53 def right?() 54 @right != nil 55 end 56 def is_left?(parent) 57 self == parent.left 58 end 59 def is_right?(parent) 60 self == parent.right 61 end 127 def visit_post() 128 stack = [] 129 node = self 130 while true 131 while node.left? 132 stack.push(node) 133 node = node.left 134 end 135 if node.right? 136 stack.push(node) 137 node = node.right 138 else 139 while not stack.empty? 140 yield node 141 last = stack.last() 142 if not last.right? or node.is_right?(last) 143 node = stack.pop() 144 else 145 node = last.right 146 break 147 end 148 end 149 if stack.empty? 150 yield node 151 break 152 end 153 end 154 end 155 end |
|
返回顶楼 | |
发表时间:2010-05-10
//非递归后序遍历二叉树 void aftorder_traverser_nonrec(BiTree root){ TreeNode *p,*q; p=q=root; //指针栈,用于存储树中的结点地址 TreeNode *stack[100]; //栈顶位置 int top=0; while(top>-1){ //堆栈所有可能的左孩子,直到没有左孩子或左或右孩子已经输出 while(p->lchild!=NULL&&q!=p->lchild&&q!=p->rchild){ stack[top++]=p; p=p->lchild; } //当前结点没有右孩子或右孩子已经输出完毕 if(p->rchild==NULL||q==p->rchild){ visit(p); //输出结点 if(top==0) --top;//说明栈中的结点全部处理完 else{ q=p; p=stack[--top]; } }else{//向右孩子前进一步 stack[top++]=p p=p->rchild; } } } 程序没有编译,随手写了一下,应该没有逻辑错误 |
|
返回顶楼 | |
浏览 5146 次