我正在尝试在优先级队列的堆实现中执行快速合并功能。我将 heappqueue 的“堆”数组(字符串)加倍,开始。我是否认为“string first = one->heap[count]”会给我一个名为“first”的字符串,它是数组“heap”(heappqueue 类中的私有成员数组)中 int count 处的字符串?我得到了一些奇怪的结果...
HeapPQueue *HeapPQueue::merge(HeapPQueue *one, HeapPQueue *two) {
one->expandCapacity();// Double heappqueue one's heap capacity
int size2 = two->logSize;
int count = 1;
for (int i = size2 + 1; i <= size2 * 2; i++) {// concatinate heaps by copying heappqueue one's heap again
string first = two->heap[count];
one->heap[i] = first;
count++;
one->logSize++;// increase heapqueue one's logSize as it copies
}
int index = one->logSize;
one->reverseHeapify(index);// call to private member function on heappqueue one
return one;
}
void HeapPQueue::reverseHeapify(int index) {
if (index == 1) return; // base case
string this1 = heap[index];
string node1 = heap[index / 2];
if (node1 > this1) {
heap[index / 2] = this1;
heap[index] = node1;
}
reverseHeapify(index - 1);
}