频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

C++数据结构学习:二叉树(1)

来源:CSDN 作者:happycock 出处:巧巧读书 2005-11-07 进入讨论组
上一页 1 2 3 4 
  
  当有parent指针时,可以不用栈实现非递归的中序遍历,书上提到了有这种方法,但没给出例程。
  
  public:
  
  BTNode*next()
  
  {
  
  if(!current)returnNULL;
  
  if(current->right){current=current->right;while(current->left)current=current->left;}
  
  else
  
  {
  
  BTNode*y=current->parent;
  
  while(y&¤t==y->right){current=y;y=y->parent;}
  
  current=y;
  
  }
  
  returncurrent;
  
  }
  
  private:
  
  BTNode*current;
  
  上面的函数能使current指针向前移动一个位置,如果要遍历整棵二叉树,需要使current指向中序序列的第一个节点,例如下面的成员函数:
  
  public:
  
  voidfirst(){current=root;while(current->left)current=current->left;}
专题:http://www.qqread.com/cpp/p520596030.html 更多文章 更多内容请看数据结构C/C++技术专题数据结构教程专题,或进入讨论组讨论。
上一页 1 2 3 4 
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章