新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   >>中国XML论坛<<     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 研友的交流园地,讨论关于计算机考研的方方面面。
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机理论与工程『 计算机考研交流 』 → 张铭《数据结构与算法》书中三个非递归周游二叉树算法的改进 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 6247 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 张铭《数据结构与算法》书中三个非递归周游二叉树算法的改进 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     chyl 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(高数修炼中)
      文章:12
      积分:120
      门派:XML.ORG.CN
      注册:2006/8/2

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给chyl发送一个短消息 把chyl加入好友 查看chyl的个人资料 搜索chyl在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看chyl的博客楼主
    发贴心情 张铭《数据结构与算法》书中三个非递归周游二叉树算法的改进

    觉得书中的算法结构不是很明晰,自己改进了一下。算法在C++下编译成功。
    为比较常用的回溯结构,尤其是第三个算法,个人认为比书上那个清楚很多呵呵。
    希望大家多提意见,共同进步。
    一、前序周游
    void BinaryTree::PreOrderWithoutRecursion(BinaryTreeNode* root){
        BinaryTreeNode *p;
        p=root;
        Stack *s=new Stack(20);
        while(1){
            if(p){
                p->visit();
                s->push(p);
                p=p->leftchild();
            }
            else{
                if(s->isEmpty()) return;
                p=s->getTop();
                s->pop();
                p=p->rightchild();
            }
        }
    }

    二、中序周游
    void BinaryTree::InOrderWithoutRecursion(BinaryTreeNode* root){
        BinaryTreeNode *p;
        p=root;
        Stack *s=new Stack(20);
        while(1){
            if(p){
                s->push(p);
                p=p->leftchild();
            }
            else{
                if(s->isEmpty()) return;
                p=s->getTop();
                s->pop();
                p->visit();
                p=p->rightchild();
            }
        }
    }

    三、
    void BinaryTree::PostOrderWithoutRecursion(BinaryTreeNode* root){
        BinaryTreeNode *p;
        p=root;
        Stack *s=new Stack(20);
        while(1){
            if(p){
                if(p->id==2){                    //p->id==2表示该点已经周游右子树
                    p->visit();
                    p=0;
                }
                else{
                    s->push(p);
                    if(p->id==0){                //表示该点未周游任何子树
                        p->id=1;
                        p=p->leftchild();
                    }
                    else if(p->id==1){          //表示该点已周游左子树
                        p->id=2;
                        p=p->rightchild();
                    }
                }                
            }
            else{
                if(s->isEmpty()) return;
                p=s->getTop();
                s->pop();
            }
        }
    }


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/8 22:26:00
     
     Supremgoooo 帅哥哟,离线,有人找我吗?
      
      
      等级:大四下学期(考上研究生啦!)
      文章:201
      积分:1872
      门派:XML.ORG.CN
      注册:2006/4/9

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Supremgoooo发送一个短消息 把Supremgoooo加入好友 查看Supremgoooo的个人资料 搜索Supremgoooo在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看Supremgoooo的博客2
    发贴心情 
    不错不错,第3个最好了!
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/9 9:24:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 计算机考研交流 』 的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/11/25 13:32:42

    本主题贴数2,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    66.406ms