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

    >> 研友的交流园地,讨论关于计算机考研的方方面面。
    [返回] 计算机科学论坛计算机理论与工程『 计算机考研交流 』 → 两个周游串构造2叉树 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 4043 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 两个周游串构造2叉树 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     chenminyi 帅哥哟,离线,有人找我吗?狮子座1984-7-28
      
      
      等级:大三(要不要学学XML呢?)
      文章:69
      积分:555
      门派:XML.ORG.CN
      注册:2006/7/20

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给chenminyi发送一个短消息 把chenminyi加入好友 查看chenminyi的个人资料 搜索chenminyi在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看chenminyi的博客楼主
    发贴心情 两个周游串构造2叉树

    template<class T>
    int prefind(T d, T *q, int tail)
    {
     for(int i = 0; i <= tail; i++)
      if(q[i]==d)return i;
     return -1;
    }

    template<class T>
    int postfind(T d, T *q, int n)
    {
     for(int i = 0; i <= n; i++)
      if(*(q-i)==d)return i;
     return -1;
    }

    template<class T>
    node<T>* preincon(T* &ph, T *qh, int n)
    {
     if(tail>=0) {
      int index = prefind(*ph++,qh,n);
      if(index==-1){
       cout << *ph <<" BadInput\n";
       return 0;
      }
      node<T>* l = preincon(ph,qh,index-1);
      node<T>* r = preincon(ph,qh+index+1,n-index-1);
      node<T>* root = new node<T>(qh[index],l,r);
      return root;
     }
     else return 0;
    }

    template<class T>
    node<T>* postincon(T* &pt, T *qh, int tail)
    {
     if(tail>=0) {
      int index = prefind(*pt--,qh,tail);
      if(index==-1){
       cout << *ph <<" BadInput\n";
       return 0;
      }
      node<T>* r = postincon(pt,qh+index+1,tail-index-1);
      node<T>* l = postincon(pt,qh,index-1);
      node<T>* root = new node<T>(qh[index],l,r);
      return root;
     }
     else return 0;
    }

    template<class T>
    node<T>* prepostcon(T* &ph, T *qt, int n)
    {
     if(n>=0) {
      if(*ph!=*qt)cout << " BadInput\n";
      T temp = *ph;
      node<T>* root;
      int index = postfind(*(++ph),qt,n);
      if(index==-1){
       root = new node<T>(temp,0,0);
       return root;
      }
      node<T>* l = prepostcon(ph,qt-index,n-index);
      node<T>* r = prepostcon(ph,qt-1,index-2);
      root = new node<T>(temp,l,r);
      return root;
     }
     else return 0;
    }


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/1/5 0:01:00
     
     chenminyi 帅哥哟,离线,有人找我吗?狮子座1984-7-28
      
      
      等级:大三(要不要学学XML呢?)
      文章:69
      积分:555
      门派:XML.ORG.CN
      注册:2006/7/20

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给chenminyi发送一个短消息 把chenminyi加入好友 查看chenminyi的个人资料 搜索chenminyi在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看chenminyi的博客2
    发贴心情 
    以前做的所以没写注释,不好意思了~呵呵~
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/1/5 0:04:00
     
     teng_t1986 帅哥哟,离线,有人找我吗?天秤座1986-10-22
      
      
      威望:1
      头衔:智能缔造者
      等级:计算机学士学位(版主)
      文章:368
      积分:2273
      门派:IEEE.ORG.CN
      注册:2006/4/8

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给teng_t1986发送一个短消息 把teng_t1986加入好友 查看teng_t1986的个人资料 搜索teng_t1986在『 计算机考研交流 』 的所有贴子 点击这里发送电邮给teng_t1986 访问teng_t1986的主页 引用回复这个贴子 回复这个贴子 查看teng_t1986的博客3
    发贴心情 
    没写注释的算法好难看懂啊……
    更郁闷的是看懂后发现你居然有先序+后序构造2*树的算法,……
    你不知道先序+后序无法确定2*树吗?
    应该是后序+层次吧……

    ----------------------------------------------
    书山奋战不觉难,
    一刻光阴莫等闲。
    长路遥遥飞浩志,
    前尘洗却作泥丸。
    粗茶薄被心灯暖,
    明月清窗几案寒。
    欲待桂枝香万里,
    海阔天空俱欢颜。

    My blog:http://hi.baidu.com/tengteng2007

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/1/6 17:12:00
     
     chenminyi 帅哥哟,离线,有人找我吗?狮子座1984-7-28
      
      
      等级:大三(要不要学学XML呢?)
      文章:69
      积分:555
      门派:XML.ORG.CN
      注册:2006/7/20

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给chenminyi发送一个短消息 把chenminyi加入好友 查看chenminyi的个人资料 搜索chenminyi在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看chenminyi的博客4
    发贴心情 
    以下是引用teng_t1986在2007-1-6 17:12:00的发言:
    没写注释的算法好难看懂啊……
    更郁闷的是看懂后发现你居然有先序+后序构造2*树的算法,……
    你不知道先序+后序无法确定2*树吗?
    应该是后序+层次吧……


    为什么不能?我不知道有理论证明不能~
    前序:根,左子树的根,……,右子树的根,……
                                      ↑                       ↑
                                   左子树                 右子树
    后序:……,左子树的根,……,右子树的根,根
               ↑                      ↑
            左子树                右子树
    通过搜索能够得到对应的左子树的前序序列和后序序列,递归即可。右子树同理。
    上诉3个算法我都上机验证过,在有限的几组事例下没有问题~
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/1/7 18:51:00
     
     GoogleAdSense狮子座1984-7-28
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 计算机考研交流 』 的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/21 0:35:48

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

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