0

我的堆基于我的 DynamicArray (ArrayList),DynamicArray 通过引用元素从列表中添加/删除。

我的问题是一个名为 fixIndexes 的函数。当在堆中添加元素时,它应该修复数组中的索引。除了最后一个元素为零外,该功能完美无缺。我认为这与将局部变量添加到数组后从堆栈中弹出有关。

我很想知道为什么这是唯一为 0 的变量,也许是更好的方法或解决方案。

DynamicArray 签名:

bool add(T& element);
void set(uint index, T& value);
T& remove(uint index);
uint getSize();

代码:

#include <iostream>
#include "../DynamicArray/DynamicArray.h"
using namespace std;
using namespace triforce;

DynamicArray<int> array;

void fixIndexes(uint start, int& elemToSet)
{
    if(start >= array.getSize())
    {   
        cout << "Start: " << start << " elemToSet: " << elemToSet << "\n";
        int temp = elemToSet;
        cout << "Temp: " << temp << "\n";
        array.add(temp);
    }   
    else
    {   
        cout << "Start: " << start << " elemToSet: " << elemToSet << "\n";
        int temp = array.get(start);
        array.set(start, elemToSet);
        fixIndexes((start * 2) + 1, temp);
    }   

}

int main()
{
    int val0 = 1;
    int val1 = 2;
    int val2 = 3;
    int val3 = 4;
    int val4 = 5;
    int val5 = 6;
    int val6 = 7;
    int val7 = 8;
    int val8 = 9;
    int val9 = 10; 
    int val10 = 11; 
    int val11 = 12; 
    int val12 = 13; 
    int val13 = 14; 
    int val14 = 15; 

    int val15 = 2;

    array.add(val0);
    array.add(val1);
    array.add(val2);
    array.add(val3);
    array.add(val4);
    array.add(val5);
    array.add(val6);
    array.add(val7);
    array.add(val8);
    array.add(val9);
    array.add(val10);
    array.add(val11);
    array.add(val12);
    array.add(val13);
    array.add(val14);
    cout << array.toString() << "\n";

    fixIndexes(1, val15);
    cout << array.toString() << "\n";

    return 0;
}

输出:

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]

Start: 1 elemToSet: 2
Start: 3 elemToSet: 2
Start: 7 elemToSet: 4
Start: 15 elemToSet: 8
Temp: 8
[1, 2, 3, 2, 5, 6, 7, 4, 9, 10, 11, 12, 13, 14, 15, 0]
4

0 回答 0