C++中编程出现function does not take 1 parameters,求指正

#include<iostream>usingnamespacestd;typedefcharTElemType;constcharspace='^';constintM... #include <iostream>
using namespace std;
typedef char TElemType;
const char space='^';
const int MAX_NODE_COUNT=20;
typedef struct BTreeNode
{
TElemType data;
struct BTreeNode *left ,*right;
}*Root;
class BTree
{
Root rt;
public:
BTree (){rt=NULL;}
void CreateBTree();
void DLRTraverse();
void LDRTraverse();
void LRDTraverse();
int depth();
};

void BTree::CreateBTree()
{
char value;
cin>>value;
if (value==space)
return;
rt=new BTreeNode;
rt->data=value;
BTree left,right;
left.CreateBTree();
right.CreateBTree();
rt->left=left.rt;
rt->right=right.rt;
}

void BTree::DLRTraverse()
{
if (rt)
{
BTree left,right;
left.rt=rt->left;
right.rt=rt->right;
cout<<rt->data;
left.DLRTraverse();
right.DLRTraverse();
}
}

void BTree::LDRTraverse()
{
if (rt)
{
BTree left,right;
left.rt=rt->left;
right.rt=rt->right;
left.LDRTraverse();
cout<<rt->data;
right.LDRTraverse();
}
}

void BTree::LRDTraverse()
{
if (rt)
{
BTree left,right;
left.rt=rt->left;
right.rt=rt->right;
left.LRDTraverse();
right.LRDTraverse();
cout<<rt->data;
}
}

int BTree::depth(rt)
{
int dep1,dep2;
if(rt==NULL) return 0;
else
{
dep1=depth(rt->left );
dep2=depth(rt->right );
return (dep1>dep2?(dep1+1):(dep2+1));
}
}

void main()
{
BTree T;
T.CreateBTree();
T.DLRTraverse();cout<<endl;
T.LDRTraverse();cout<<endl;
T.LRDTraverse();cout<<endl;
T.depth();cout<<endl;
}
展开
 我来答
IT孤鹜
2014-05-07 · TA获得超过4198个赞
知道大有可为答主
回答量:3960
采纳率:71%
帮助的人:3594万
展开全部

好了,测试通过,请采纳

#include <iostream>
using namespace std;
typedef char TElemType;
const char space='^';
const int MAX_NODE_COUNT=20;
typedef  struct BTreeNode
{
    TElemType  data;
    struct BTreeNode *left ,*right;
}*Root;
class BTree
{
public:
    Root rt;
public:
    BTree (){rt=NULL;}
    void CreateBTree();
    void DLRTraverse();
    void LDRTraverse();
    void LRDTraverse();
    int depth(Root);
};

void BTree::CreateBTree()
{
    char value;
    cin>>value;
    if (value==space)
        return;
    rt=new BTreeNode;
    rt->data=value;
    BTree left,right;
    left.CreateBTree();
    right.CreateBTree();
    rt->left=left.rt;
    rt->right=right.rt;
}

void BTree::DLRTraverse()
{
    if (rt)
    {
        BTree left,right;
        left.rt=rt->left;
        right.rt=rt->right;
        cout<<rt->data;
        left.DLRTraverse();
        right.DLRTraverse();
    }
}

void BTree::LDRTraverse()
{
    if (rt)
    {
        BTree left,right;
        left.rt=rt->left;
        right.rt=rt->right;
        left.LDRTraverse();
        cout<<rt->data;
        right.LDRTraverse();
    }
}

void BTree::LRDTraverse()
{
    if (rt)
    {
        BTree left,right;
        left.rt=rt->left;
        right.rt=rt->right;
        left.LRDTraverse();
        right.LRDTraverse();
        cout<<rt->data;
    }
}

int BTree::depth(Root rt)
{
    int dep1,dep2;
    if(rt==NULL) return 0;
    else
    {
        dep1=depth(rt->left );
        dep2=depth(rt->right );
        return (dep1>dep2?(dep1+1):(dep2+1));
    }
}

void main()
{
    BTree T;
    T.CreateBTree();
    T.DLRTraverse();cout<<endl;
    T.LDRTraverse();cout<<endl;
    T.LRDTraverse();cout<<endl;
    cout<<T.depth(T.rt);cout<<endl;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式