0

我正在尝试在优先级队列的堆实现中执行快速合并功能。我将 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);

}
4

0 回答 0