我是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(){}'? –