我是C ++世界的新手,我需要帮助。我的问题是我尝试实现我的结构哈希对数组,有密钥和数据。在这个结构中,我有嵌套结构迭代器,方法有hasNext和next。因为我无法从嵌套结构中看到我的数组(此数组在父级中),我需要通过构造函数传递它,但是有错误“:无法从...转换”,问题在于方法getIterator中的pass _array。代码如下。你可以帮帮我吗?感谢
#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);
}
};
答案 0 :(得分:0)
据我所知,问题出在这一行:
\w
在这里,您声明一个大小为Par* _array[Size];
的{{1}}结构指针数组,这可能不是您想要的。
稍后您尝试将此数组传递给构造函数Size
,该构造函数接受指向Par
结构的指针,这是不可能的。
我会按以下方式修复此代码:
iterator(Par * _array)
另外,请考虑使用Par
而不是原始指针。它将为您处理内存管理问题。