1

我有一个二叉搜索树作为二叉树的派生类,现在我正在尝试访问我的递归函数(在基类中)的根。但由于某种原因,我不断收到错误:

binSTree.h:31: error: ‘root’ was not declared in this scope

这是我的班级声明:

基类:

template <class T>
class binTree {
private:

  int height(treeNode<T>*) const;          // Recursive method
  int size(treeNode<T>*) const;            // Recursive method
  int leaves(treeNode<T>*) const;

  void insert(treeNode<T>*&, const T&);

  void clear(treeNode<T>*);
  treeNode<T>* copy_tree(treeNode<T>*);

  void preOrder(treeNode<T>*, void (*)(T&));
  void inOrder(treeNode<T>*, void (*)(T&));
  void postOrder(treeNode<T>*, void (*)(T&));
public:
   binTree();
   binTree(const binTree<T>&);
   ~binTree();

   bool empty() const;

   void clear();

   void insert(const T&);
   int remove(const T&);                 // Extra credit only

   int height() const;                   // Non-recursive method
   int size() const;                     // Non-recursive method
   int leaves() const;

   void preOrder(void (*)(T&));
   void inOrder(void (*)(T&));
   void postOrder(void (*)(T&));

   const binTree<T>& operator=(const binTree<T>&);
protected:
   treeNode<T>* root;
};

头文件(到第 31 行):

#include "binTree.h"

template<class T>
class binSTree : public binTree<T> {
public:
  void insert(const T&);
  bool remove(const T&);
  bool search(const T&, int&) const;
private:
  void insert(treeNode<T>*&, const T&);
  bool remove(treeNode<T>*&, const T&);
  bool search(treeNode<T>*, const T&, int&);
  void remove_root(treeNode<T>*&);
};

template<class T>
void binSTree<T>::insert(const T& x) {
treeNode<T>* newNode = new treeNode<T>(x);
insert(newNode, x);
}

template<class T> // public
bool binSTree<T>::remove(const T& x) {
return remove(binTree<T>.root, x);
}

template<class T> // public
bool binSTree<T>::search(const T& x, int& len) const {
len = 0;
len = search(root,x,len);
}

我尝试公开根目录以查看会发生什么,但我仍然遇到同样的错误。

任何帮助将非常感激!

4

2 回答 2

1

我不知道这是为什么,但是当从模板类进行子类化时,为了访问成员,您需要在它们前面加上基类名称。

len = search( binTree<T>::root, x,len);

我的编译器 Visual C++ 不需要这个,但标准出于某种原因需要。或者,您可以输入以下行:

using binTree<T>::root;

在任何需要它的范围内。

编辑: heavd 告诉我你可以使用这个:

this->root
于 2010-10-22T03:00:21.427 回答
0

没有完整的代码很难判断,但值得注意的是,类模板通常不会像您在此处那样将代码与声明分开,这对于非模板类来说是典型的。

我会将类模板代码移动到您的头文件中(因为这是您可能希望它前进的方式)并查看结果是什么。如果您仍然有问题,请发布修改后的代码以及对错误消息的任何相关更新。

于 2010-10-22T02:39:44.013 回答