我是C++世界的新手,我需要幫助。我的問題是我嘗試實現我的結構散列對數組,有關鍵和數據。在這個結構中,我使用方法hasNext和next嵌套了結構迭代器。因爲我不能從嵌套結構中看到我的數組(這個數組在父類中),所以我需要通過構造函數傳遞它,但是出現錯誤「:can not convert from ...」,問題是在方法getIterator中傳遞_array。代碼如下。你可以幫幫我嗎?由於帶有hasNext和Next的C++迭代器
#pragma once
template<typename T, typename U, int Size, int(*HashFunction)(T)>
struct HashPairPole {
// Pair - key - data
struct Par {
// key
T _first;
// data
U _second;
// list for collision records
Par* _overflow;
Par(T t, U u) {
_first = t;
_second = u;
_overflow = nullptr;
}
};
HashParovePole() {}
// Static array for save data
Par* _array[Size];
// Add record into hash table
void add(T t, U u) {
// calculating of index
Par* prvek;
int idx = HashFunction(t) % Size;
// Element will be saved in _array[idx], if it is free, else will be
//saved to list (->_overflow)
prvek = new Par(t, u);
if (_array[idx] == nullptr) {
_array[idx] = prvek;
}
else {
prvek->_overflow = _array[idx];
}
_array[idx] = prvek;
}
// Get data from hash tabule
U& get(T t) {
int idx = HashFunction(t) % Size;
Par * prvni = _array[idx];
while (prvni->_overflow != nullptr) {
if (prvni->_first == t) {
return prvni->_second;
}
prvni = prvni->_overflow;
}
}
U& operator[](T t) {
return get(t);
}
U operator[](T t) const {
const U temp = get(t);
return temp;
}
// Iterator for walking all hash table
struct iterator {
Par* index[Size];
Par* pomPar;
int temp = 0;
iterator(Par * _array) {
index = _array;
pomPar = index[0];
}
bool hasNext()const {
return pomPar != nullptr;
}
std::pair<T, U> next() {
std::pair<T, U> data;
if (hasNext()) {
data.first = pomPar->_first;
data.second = pomPar->_second;
pomPar = pomPar->_overflow;
}
temp++;
pomPar = index[temp];
return data;
}
};
// Vytvori iterator
iterator getIterator() {
return iterator(_array);
}
};
在哪行中有彙編錯誤?什麼是編譯錯誤的文本?請閱讀FAQ併發布MCVE:http://stackoverflow.com/help/mcve – alexeykuzmin0
'Par * _array!= Par * index [Size]'。 – NathanOliver
關閉主題,但...我猜'HashParovePole(){}'應該是'HashPairPole(){}'? –