C ++仍然相当新,并试图在这里提升一个档次。我想构建一个带有嵌套Node类的Heap类,并向Heap类添加堆排序方面。我已经用Java做了类似的事情,但是我试图在.cpp文件中定义嵌套类时遇到困难。
#pragma once
#ifndef HEAP_H
#define HEAP_H
template <class T>
class Heap
{
public:
class Node
{
public:
Node(T);
T data;
private:
Node *parent;
Node *left_child;
Node *right_child;
boolean is_root;
};
Heap(T*, int);
sort_it();
private:
T *unsorted_list
Node root;
void build_heap();
void add_node(Node);
void swap_root();
void trickle_down();
void heap_sort();
};
#endif
现在,当我在.cpp文件中定义我的嵌套类时,我不能简单地...
#include "stdafx.h"
#include "Heap.h"
#include <iostream>
//Defining Heap Constructor
Heap::Heap(T* incoming_array, int _size)
{
unsorted_list = incoming_array;
size = _size;
}
//Defining Node Constructor
Heap::Node(T _data)
{
data = _data;
left_child = right_child = parent = Null;
is_root = false;
}
我不确定我的问题是我如何合并模板,或者我的定义内部类的语法是错误的。在C ++中我不熟悉泛型编程和嵌套类
答案 0 :(得分:1)
如果在嵌套类中使用任何泛型类型,则必须指定模板。
template<class T>
class Node
在类外定义模板类构造函数
template<typename T>
Node<T>::Node(T _data)
声明成员如下,
Node<T> root