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

    >> 研友的交流园地,讨论关于计算机考研的方方面面。
    [返回] 计算机科学论坛计算机理论与工程『 计算机考研交流 』 → 我写的后序周游非递归算法 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 7912 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 我写的后序周游非递归算法 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     mxf3306 帅哥哟,离线,有人找我吗?
      
      
      等级:大三(研究MFC有点眉目了!)
      文章:112
      积分:823
      门派:XML.ORG.CN
      注册:2006/7/6

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给mxf3306发送一个短消息 把mxf3306加入好友 查看mxf3306的个人资料 搜索mxf3306在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看mxf3306的博客楼主
    发贴心情 我写的后序周游非递归算法

    public void postOrderTraverse() {
            Stack<StackElement> stack = new Stack<StackElement>();
            BinaryTreeNode node = root;
            StackElement element = null;
            while (stack.size() > 0 || node != null) {
                if (node != null) {
                    //从父节点进入
                    if (element == null || element.getNode() != node) {
                        element = new StackElement();
                        element.setNode(node);
                        element.setFrom(Direction.left);
                        stack.push(element);
                        node = node.getLeft();
                    }
                    //从左子树返回
                    else if (element.getFrom() == Direction.left) {
                        element.setFrom(Direction.right);
                        stack.push(element);
                        node = node.getRight();
                    }
                    //从右子树返回
                    else if (element.getFrom() == Direction.right) {
                        BinaryTreeNode.visit(element.getNode());
                        node = null;
                    }
                } else {
                    element = stack.pop();
                    node = element.getNode();
                }
            }
        }

    我写的后序周游非递归算法,测试过几颗树均无问题,不过不敢保证完全正确,贴出来请大家批评指正。


       收藏   分享  
    顶(1)
      




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

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Supremgoooo发送一个短消息 把Supremgoooo加入好友 查看Supremgoooo的个人资料 搜索Supremgoooo在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看Supremgoooo的博客2
    发贴心情 
    没问题,对!
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/27 20:56:00
     
     Supremgoooo 帅哥哟,离线,有人找我吗?
      
      
      等级:大四下学期(考上研究生啦!)
      文章:201
      积分:1872
      门派:XML.ORG.CN
      注册:2006/4/9

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Supremgoooo发送一个短消息 把Supremgoooo加入好友 查看Supremgoooo的个人资料 搜索Supremgoooo在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看Supremgoooo的博客3
    发贴心情 
    仔细思考了一下,发现你这个框架很不错啊!

    有两处优点:
    (1)这不仅是一个后序框架,还是一个前序,中序框架。
    (2)这个算法框架一句废话都没有,stack里面一个冗余点都没有。就是说:这个算法框架已经精简到再精简就错误的地步了

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/28 12:50:00
     
     pkurao 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:1
      积分:72
      门派:XML.ORG.CN
      注册:2005/4/11

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给pkurao发送一个短消息 把pkurao加入好友 查看pkurao的个人资料 搜索pkurao在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看pkurao的博客4
    发贴心情 
    其实很多书上都是把正在访问的节点(即书上认为是从右边拉回来的节点)的右节点跟最近访问的那个节点比较,如果是则是从右链回来的,所以不需要再进右边,如果不是则进入右边。因此只要多个模块级变量即可解决是否从右链回来的问题,书上的太烦琐了。
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/28 18:26:00
     
     msychailce 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(高数修炼中)
      文章:15
      积分:166
      门派:XML.ORG.CN
      注册:2006/8/13

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给msychailce发送一个短消息 把msychailce加入好友 查看msychailce的个人资料 搜索msychailce在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看msychailce的博客5
    发贴心情 
    我改了一下书上的算法,让每一节点只进一次栈,不知道对不对,请大家指点。
    enum Tags{left,right};
    template<class T>
    class StackElement
    {
     public:
        BinaryTreeNode<T> * point;
        Tags tag;
    };

    void BinaryTree<T>::PostOrderWithoutRecursion(BinaryTreeNode<T> * root)
    {
     using std::stack;
     StackElement<T> element;
                    stack < StackElement<T> > aStack;
     BinaryTreeNode<T> * point ;
       if (root == NULL)
          return;
       else point = root;
     while (TRUE)
     { 
      while(point)  
      {
       element.point = point;
       element.tag = left;
       aStack.push(element);  //入栈 
       point = point->leftchild();
      }
      
      element = aStack.top();
      point = element.point;
      // aStack.pop();    

      while(element->tag == right)
      {
       visit(point->vaule());
       aStack.pop();      //出栈

       if(aStack.empty())
        return;    
       else
       {
        element = aStack.top();
                                      point = element.point;
                                                           //  aStack.pop();
       }
      }

      element->tag = right;  
                     //  aStack.push(point);
      point = point->rightchild();  
     }

    }

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

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Supremgoooo发送一个短消息 把Supremgoooo加入好友 查看Supremgoooo的个人资料 搜索Supremgoooo在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看Supremgoooo的博客6
    发贴心情 
    对。你这是利用stl的特点,本质上和二次入栈的一样
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/31 19:03:00
     
     msychailce 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(高数修炼中)
      文章:15
      积分:166
      门派:XML.ORG.CN
      注册:2006/8/13

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给msychailce发送一个短消息 把msychailce加入好友 查看msychailce的个人资料 搜索msychailce在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看msychailce的博客7
    发贴心情 
    supremgoooo说的对,我的这种在本质上没什么改进,如果非stl栈是要弹出的,就相当于aStack.top()和aStack.pop()应该是绑在一起的。
    嗯,受教。谢谢supremgoooo兄。
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/9/1 9:52:00
     
     Supremgoooo 帅哥哟,离线,有人找我吗?
      
      
      等级:大四下学期(考上研究生啦!)
      文章:201
      积分:1872
      门派:XML.ORG.CN
      注册:2006/4/9

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Supremgoooo发送一个短消息 把Supremgoooo加入好友 查看Supremgoooo的个人资料 搜索Supremgoooo在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看Supremgoooo的博客8
    发贴心情 
    昨天没仔细看,你这个程序有有问题啊:
    举一个例子:
    int main()
    {
          int a,b;
          a=5;
          b=a;
          b=3;
          cout<<a;
          return 0;
    }
    结果是5,不是3。你的算法也有此问题,element相当于b,栈顶的元素相当于a,你想通过b来改变a的值,需要引用才行,如:
    int main()
    {
          int a,&b;
          a=5;
          b=a;
          b=3;
          cout<<a;
          return 0;
    }
    结果是3。这是一个C语言容易错的地方,你自己该下算法吧。
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/9/1 18:41:00
     
     mxf3306 帅哥哟,离线,有人找我吗?
      
      
      等级:大三(研究MFC有点眉目了!)
      文章:112
      积分:823
      门派:XML.ORG.CN
      注册:2006/7/6

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给mxf3306发送一个短消息 把mxf3306加入好友 查看mxf3306的个人资料 搜索mxf3306在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看mxf3306的博客9
    发贴心情 
    我这个算法其实就是参照课本的前中序遍历写的,这两个遍历写得很简洁,不知为何后序却风格大变,而且逻辑不是很清楚,看了好几遍还是很晕,算法改写后跟前中序风格一样就很容易记住了。
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/9/1 22:01:00
     
     springy126 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:4
      积分:81
      门派:XML.ORG.CN
      注册:2006/9/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给springy126发送一个短消息 把springy126加入好友 查看springy126的个人资料 搜索springy126在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看springy126的博客10
    发贴心情 
    很好的算法,谢谢lz
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/9/15 10:12:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 计算机考研交流 』 的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/6 5:40:58

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

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