作业分配要求为Heap类重载寄售操作符,该类用于存储指向每个节点上的队列的指针,以尝试模拟应急空间优先级队列。重载赋值运算符C++
到目前为止,这里是代码,我想出了:
template <typename T>
Heap<T>& Heap<T>::operator=(const Heap<T> & rhs)
{
//check for self-assignment
if(this != &rhs)
{
//delete memory
for(int i = 0; i < MAX_HEAP; i++)
{
//delete queue at position i, set pointer to NULL
delete items[i];
items[i] = NULL;
}//end for
delete * items;
//create new memory to hold copy of rhs
//error occurs here
items = new queue<T> *[MAX_HEAP] ;
for(int i = 0; i < MAX_HEAP; i++)
items[i] = rhs.items[i];
//assigns new stuff to this heap
size = rhs.size;
nodes = rhs.nodes;
}//end if
return *this;
}//end =
的项目在头文件中声明为这样:
queue<T>* items[MAX_HEAP];
和标准库队列的一个实例。
我不太清楚如果我使用正确的语法来创建一个新的动态数组队列指针。
我得到一个错误,指出:
error C2440: '=' : cannot convert from 'std::queue<_Ty> **' to 'std::queue<_Ty> *[50]'
任何想法,以什么可能导致它,我该怎么解决呢?
对于显着更少的痛苦,请使用[copy-and-swap idiom](http://stackoverflow.com/questions/3279543/what-is-the-copy-and-swap-idiom)。 – 2012-04-26 20:34:04
为什么不只是使用'std :: vector'而不是C数组和手动内存管理?将标准库类和C数组混合在一起是愚蠢的矫枉过正。 – Griwes 2012-04-26 20:34:29
堆将如何使用队列指针的动态数组? – 2012-04-26 20:43:43