下面我有一个Min Heap的标准插入和删除功能,我需要做的是当T.num比较碰巧相等时为这两个函数添加一个特殊情况,然后我需要比较T 。字母首先弹出较低的Ascii值。没有评论是标准插入和删除,添加评论部分将是我尝试添加新功能,这对于我的生活,我不明白为什么它不会工作。
void MinHeap<T>::insert(T& e)
{
int CurrNode = ++HeapSize;
while(CurrNode != 1 && heap[CurrNode/2].num >= e.num)
{
/*
if(heap[CurrNode/2].num == e.num)
if(heap[CurrNode/2].letter <= e.letter)
break;
*/
heap[CurrNode] = heap[CurrNode/2];
CurrNode /= 2;
}
heap[CurrNode] = e;
}
void MinHeap<T>::delet()
{
T LastNode = heap[HeapSize--];
int CurrNode = 1;
int child = 2;
while(child <= HeapSize)
{
if(child < HeapSize && heap[child].num >= heap[child+1].num)
{
/*
if(heap[child].num == heap[child+1].num)
if(heap[child].letter <= heap[child+1].letter)
child--;
*/
child++;
}
if(LastNode.num <= heap[child].num)
{
/*
if (LastNode.num == heap[child].num)
{
if (LastNode.letter <= heap[child].letter)
break;
}
else
*/
break;
}
heap[CurrNode] = heap[child];
CurrNode = child;
child *= 2;
}
heap[CurrNode] = LastNode;
}
答案 0 :(得分:1)
您可以简单地重载T
类型的比较运算符,如下所示:
bool operator >(const T &left, const T &right) {
return left.num > right.num ||
left.num == right.num && left.letter <= right.letter;
}
然后将heap[CurrNode/2].num >= e.num
替换为heap[CurrNode/2] > e
。
最好避免使用注释部分中的代码,因为它很快就会让人难以理解并进行调试。