Когда я пытаюсь скомпилировать, я получаю странную ошибку: «переопределение типа возвращаемого значения виртуальной функции отличается и не является ковариантным», я думаю, что проблема в Node. Я думаю, что BTree<T>::Node
- это не то же самое, что BSTree<T>::Node
.
Базовый класс:
#ifndef BINARY_TREE_H
#define BINARY_TREE_H
template < typename T >
class BTree {
protected:
struct Node {
T key;
Node* left;
Node* right;
Node() {}
Node(
const T& key,
Node* left = nullptr,
Node* right = nullptr)
: left(left), right(right), key(key) {}
};
public:
BTree();
virtual ~BTree();
virtual Node* search(const T& key);
private:
Node* search(const T& key, Node* root);
private:
Node* root;
};
template < typename T >
typename BTree<T>::Node* BTree<T>::search(const T& key, BTree<T>::Node* root) {
//some code
}
template < typename T >
typename BTree<T>::Node* BTree<T>::search(const T& key) {
return search(key, root);
}
#endif // BINARY_TREE_H
Производный класс:
#ifndef BINARY_SEARCH_TREE_H
#define BINARY_SEARCH_TREE_H
#include "binary_tree.h"
template < typename T >
class BSTree : public BTree<T> {
protected:
struct Node {
T key;
Node* left;
Node* right;
Node() {}
Node(
const T& key,
Node* left = nullptr,
Node* right = nullptr)
: left(left), right(right), key(key) {}
};
public:
BSTree();
~BSTree() override;
Node* search(const T& key) override;
private:
Node* search(const T& key, Node* root);
private:
Node* root;
};
template < typename T >
typename BSTree<T>::Node* BSTree<T>::search(const T& key, BSTree<T>::Node* root) {
//some code
}
template < typename T >
typename BSTree<T>::Node* BSTree<T>::search(const T& key) {
return search(key, root);
}
#endif // BINARY_SEARCH_TREE_H