Я создаю HashTable в C, который использует двойной указатель Node и использует отдельную цепочку для разрешения коллизий, но когда я запускаю свой код, он не помещает коллизии в связанный список.
HTable *createTable(size_t size, int (*hashFunction)(size_t tableSize,
int key),void (*destroyData)(void *data),void (*printData)(void
*toBePrinted)){
HTable * h = malloc(sizeof(HTable));
h->size = size;
h->destroyData = destroyData;
h->hashFunction = hashFunction;
h->printData = printData;
h->table = malloc(h->size * sizeof(Node*));
for(int i = 0; i < h->size; i++){
h->table[i] = malloc(sizeof(Node));
h->table[i]->key = 0;
h->table[i]->data = NULL;
h->table[i]->next = NULL;
}
return h;
}
Node *createNode(int key, void *data){
Node * n = malloc(sizeof(Node));
n->key = key;
n->data = data;
n->next = NULL;
return n;
}
void insertData(HTable *hashTable, int key, void *data){
if(hashTable != NULL){
Node * n = createNode(key, data);
int index = hashTable->hashFunction(hashTable->size, key);
if(hashTable->table[index] != NULL)
if(hashTable->table[index]->key == key){
if(hashTable->table[index]->next != NULL){
n->next = hashTable->table[index]->next;
hashTable->table[index] = n;
}
else
hashTable->table[index] = n;
}
else{
if(hashTable->table[index]->next != NULL){
Node * itr = hashTable->table[index];
while(itr->next != NULL){
itr = itr->next;
}
itr->next = n;
}
else
hashTable->table[index] = n;
}
else{
hashTable->table[index] = n;
}
}
}
иУдары HTable и Удары Node выглядят следующим образом:
typedef struct Node
{
int key;
void *data;
struct Node *next;
} Node;
typedef struct HTable
{
size_t size;
Node **table;
void (*destroyData)(void *data);
int (*hashFunction)(size_t tableSize, int key);
void (*printData)(void *toBePrinted);
}HTable;
Я думаю, что у меня возникла проблема в моей функции insertData, когда я использую итератор для поиска последнего элемента в связанном списке.Это или я неправильно понимаю двойной указатель на узел.