我有以下形式的代码:
class Trie{
public:
Trie( ) : root( new TrieNode( ) ){ };
// Inserts a word into the trie.
void insert( std::string word );
// Returns if the word is in the trie.
bool search( std::string word );
// Returns if there is any word in the trie
// that starts with the given prefix.
bool startsWith( std::string prefix );
private:
class TrieNode;
std::unique_ptr<TrieNode> root;
};
class Trie::TrieNode{
public:
TrieNode( ) : eow( false ){ };
TrieNode* appendChar( char tar );
void end( );
bool isEnd( );
TrieNode* getChar( char tar );
int getInd( char tar );
private:
std::array<std::unique_ptr<TrieNode>, 26> data;
bool eow; // End of word
};
但是,在第三行
Trie(): root( new TrieNode() )
上,编译器继续抱怨TrieNode
不完整。我该如何解决?谢谢!
最佳答案
在Trie
定义之后定义TrieNode
的构造函数
class Trie::TrieNode{...}
// must be AFTTER the class Trie is fully defined
Trie::Trie( ) : root( new TrieNode( ) ){ };
否则
Trie
的构造函数需要TrieNode
的完整定义,因为它需要构造一个新对象,因此会出现错误。关于c++ - 嵌套类的类型不完整,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/35050373/