标题:求助一道数据结构 二叉树 的问题
只看楼主
player3333
该用户已被删除
 问题点数:0 回复次数:7 
求助一道数据结构 二叉树 的问题
提示: 作者被禁止或删除 内容自动屏蔽
搜索更多相关主题的帖子: 二叉树 数据结构 
2008-06-01 20:27
mklzdd
Rank: 1
等 级:新手上路
帖 子:41
专家分:0
注 册:2007-11-24
得分:0 
好久没有看过了,基本上也是忘的差不多了…………(貌似一开始就没有弄懂……)
2008-06-01 21:54
kongwei254
Rank: 1
等 级:等待验证会员
帖 子:38
专家分:0
注 册:2008-5-18
得分:0 
2008-06-22 17:34
geninsf009
Rank: 3Rank: 3
等 级:论坛游民
威 望:8
帖 子:613
专家分:95
注 册:2008-8-16
得分:0 
我可以写非递归的算法吗?
2008-08-22 23:46
geninsf009
Rank: 3Rank: 3
等 级:论坛游民
威 望:8
帖 子:613
专家分:95
注 册:2008-8-16
得分:0 
//////////////////////////////////////////////////
//公有成员函数preOrder()
//非递归求前序遍历中第k个结点指针的算法
//////////////////////////////////////////////////
template<class T>
BinTreeNode<T>* BinaryTree<T>::preOrder(int k)
{
    //回溯用的堆栈
    LinkedStack<BinTreeNode<T>* > LS;
    //结点遍历指针
    BinTreeNode<T>* p=root;
    //先把空指针入堆栈
    LS.Push(NULL);
    //遍历的过程
    int  count=0;         //计数器
    while(p!=NULL)
    {
    count++;         //访问当前结点
         if(count==k)     //找到第k个结点
              return p;
    if(p->rightChild!=NULL)      //如果右子结点不空
         LS.Push(p->rightChild); //把由子结点指针入栈
    if(p->leftChild!=NULL)       //如果左子结点不空
         p=p->leftChild;         //进入左子树
    else                         //如果左子树为空
         LS.Pop(p);              //回溯到右子树
    }
        return NULL;                  //没有找到
};
///////////////////////////////preOrder()函数结束

看看了你的题目,刚刚写的程序,在我写的BinaryTree<T>类模板里添加了一个这个刚写的成员函数,供你参考,
另外LinkedStack<T>是我写的一个链栈的类模板,这里定义的栈是BinTreeNode<T>*类型的堆栈.

该题目的递归算法,我还在思考中,小弟不才,能力有限,,等想得有头绪了,再发代码一起讨论...

[[it] 本帖最后由 geninsf009 于 2008-8-23 00:05 编辑 [/it]]
2008-08-23 00:01
geninsf009
Rank: 3Rank: 3
等 级:论坛游民
威 望:8
帖 子:613
专家分:95
注 册:2008-8-16
得分:0 
好啦,替你搞定了,刚写的递归算法:

//////////////////////////////////////////////////
//SearchpreOrder()私有成员函数
//得到前序序列中第k个结点的指针
//////////////////////////////////////////////////
template<class T>
BinTreeNode<T>* BinaryTree<T>::SearchpreOrder(int k,BinTreeNode<T>* subTree)
{
    if(subTree!=NULL)
    {
        int T=Size(subTree);             //树的总结点数
        int TL=Size(subTree->leftChild); //树的左子树结点数
        int TR=Size(subTree->rightChild);//树的右子树结点数

        if(k==1)               //如果k=1,那要找的就是子树根结点
            return subTree;
        else if((k-1)<=TL)        //如果在左子树中
            return SearchpreOrder(k-1,subTree->leftChild);
        else if((k-1)>TL && k<=T) //如果在右子树中
            return SearchpreOrder(k-1-TL,subTree->rightChild);
        else                      //如果超过树的总结点数
            return NULL;
    }
    else
        return NULL;
};
/////////////////////////私有SearchOrder()函数结束

其中用到的Size()也是个私有递归函数,定义如下:

//////////////////////////////////////////////////
//私有成员函数Size()
//得到二叉树的总接点的个数
//////////////////////////////////////////////////
template<class T>
int BinaryTree<T>::Size(BinTreeNode<T>* subTree)
{
    //子树为空,则结点数为0
    if(subTree==NULL)
         return 0;
    else
         return 1+Size(subTree->leftChild)+Size(subTree>rightChild);
};
////////////////////////////////////Size()函数结束

[[it] 本帖最后由 geninsf009 于 2008-8-23 20:09 编辑 [/it]]
2008-08-23 20:05
geninsf009
Rank: 3Rank: 3
等 级:论坛游民
威 望:8
帖 子:613
专家分:95
注 册:2008-8-16
得分:0 
我是又为我的BinaryTree<T>增加了一个新的成员函数,
你可能不太好直接调试,不过你可以照着我的思想自己再编写的,
我已经调试过了,结果是正确的.
2008-08-23 20:08
geninsf009
Rank: 3Rank: 3
等 级:论坛游民
威 望:8
帖 子:613
专家分:95
注 册:2008-8-16
得分:0 
我都是经过自己的思考给别人写顶帖,
希望自己好心有好报...
2008-08-23 20:11



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-217063-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.279291 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved