int Celda :: look(int dni)
{
bool found = false;
int i = 0; int pos = -1;
//tam_ sometimes have a strange value, but I only
while(i < tam_ && !found){
//touch tam_ in the constructor, is the size of Celda
if(dni == bloques_[i]){
found = true;
pos = i;
}
++i;
}
return pos;
}
在main中,我调用另一个类的方法,该类调用其他使用我在这里复制的look方法的类。在某些情况下,它可以工作,但有时程序会停止给出分段错误。
当我使用调试器时,我创建了另一个用于存储tam_值的变量(tam_是int类型),当我到达该行或while循环(条件为tam_)时,有时会出现分段错误。 / p>
Celda的构造函数是:
Celda :: Celda(int tamanio)
{
bloques_ = new int[tamanio];
bloq_ocupados_ = 0;
tam_ = tamanio;
for(int i = 0 ; i < tam_ ; ++i){
bloques_[i] = 0;
}
}
Tabla :: Tabla(int numcel, int tambloq)
{
nceldas_ = numcel;
tam_bloque_ = tambloq;
tabla_ = new Celda*[nceldas_];
for(int i = 0 ; i < nceldas_ ; ++i){
tabla_[i] = new Celda(tam_bloque_);
}
ocupadas_ = 0;
}
class Celda
{
private:
int* bloques_;
int bloq_ocupados_;
int tam_;
在公共区域
int Tabla :: busq_lineal(int dni) //si pos_dentro acaba valiendo -1, no se encontró
{
bool encontrado = false;
int pos = hash(dni), comparaciones = 0, pos_dentro, pos_fuera;
int tamaniotab = nceldas_ * tabla_[0]->gettam();
while(!encontrado && comparaciones < tamaniotab){
pos_dentro = tabla_[pos]->buscar(dni);
if(pos_dentro != -1){ //si lo encuentro...
encontrado = true;
pos_fuera = pos;
comparaciones += pos_dentro + 1;
}else if(pos < nceldas_ - 1){ //mientras no nos salgamos de la tabla, avanzamos
++pos;
comparaciones += tabla_[0]->gettam();
}else {
pos = 0; //si nos salimos, volvemos al principio
comparaciones += tabla_[0]->gettam();
}
}
return comparaciones;
}
答案 0 :(得分:1)
错误最有可能出现在这一行:
int pos = hash(dni);
正如您所说,您的hash
函数只返回dni % 199
。只有在哈希表中至少有200个项目时,这才能正常工作。
答案 1 :(得分:-2)
难道不是“i ++”吗?
for(int i = 0 ; i < tam_ ; i++){
bloques_[i] = 0;
}