错误C2661:' node :: node' :没有重载函数需要3个参数

时间:2015-05-17 18:34:18

标签: c++ visual-studio-2013 avl-tree

这是一个AVL Tree C ++程序,它具有以下资源:

"TreeNode.h"
"AVLTree.h"
"AVLTree.cpp"
"Main.cpp"

我添加了一个" TreeNode.cpp"并取了" node :: node"函数来自" AVLTree.cpp"并将其放入" TreeNod.cpp",包括" TreeNode.h"在编译之后,VS 2013会为该行抛出错误C2661:

n = new node(x, NULL, NULL);

与" AVLTree.cpp":

中的错误对应的函数
void tree::insert(int x, node* &n)
{
    if (n == NULL)
        n = new node(x, NULL, NULL);

    else if (x < n->data)
    {
        insert(x, n->l);
        if (n->l != NULL && n->r != NULL && n->l->height - n->r->height == 2)
        {
            if (x < n->l->data)
                rightrotation(n);
            else
                doublerotation_leftright(n);
        }
    }
    else if (x > n->data)
    {
        insert(x, n->r);
        if (n->r != NULL && n->l != NULL && n->r->height - n->l->height == 2)
        {
            if (n->r->data < x)
                leftrotation(n);
            else
                doublerotation_leftright(n);
        }
    }
    n->height = maxi(n->l, n->r) + 1;
}

&#34; TreeNode.cpp&#34;:

#include "TreeNode.h"

node::node(int x, node *newleft, node *newright, int h = 0)
{
    data = x;
    l = newleft;
    r = newright;
    height = h;
}

&#34; AVLTree.h&#34;:

#include "TreeNode.h"

#pragma once

class tree
{
    public:
    tree();
    ~tree();
    void insert(int x);
    bool pop(int n);
    void printpostorder();
    void printlevelorder();

    private:
    node* head;
    node* nullnode;

    void destruct(node* n);
    node* findnode(int n);
    node* min(node* n);
    node* Bfind(int n);

    void rightrotation(node* &k2);
    void leftrotation(node* &k2);
    void doublerotation_leftright(node* &k3);
    void postorder(node* n);
    void levelorder(node* n);
    void insert(int x, node* &n);
    int maxi(node *x1, node *x2);
    void balance(node* &n);
};

问题出在哪里?

编辑1:

"TreeNode.h"

#pragma once

class node
{
public:
    int data;
    node* l;
    node* r;
    int height;
    node(int x, node* newleft, node* newright, int h);
};

2 个答案:

答案 0 :(得分:2)

似乎在节点的类定义中,相应的构造函数没有第四个参数的默认参数。检查类定义并在类定义中的构造函数声明中指定默认参数,而不是在cpp文件中指定构造函数定义。

考虑到您可以使用重载的委托构造函数而不是默认参数。例如

class node
{
public:
    node(int x, node *newleft, node *newright);
    node(int x, node *newleft, node *newright, int h);
    //...

//,,,

node::node(int x, node *newleft, node *newright) : node( x, newleft, newright, 0 )
{
}

答案 1 :(得分:0)

AVLTree.cpp看不到TreeNode.cpp,所以它不知道node的构造函数的第四个参数是可选的。

将默认参数放在声明上,而不是定义上,以便在每个使用标题的翻译单元中都可以看到它。