2012-03-04 9 views
0
#include <stdio.h> 
#include <stdlib.h> 
#define true 1 

struct hashRow { 
    char *key; 
    char *value; 
}; 

struct hash_table { 
    int max; 
    int number_of_elements; 
    struct hashRow **elements; 
}; 

int hashstring(const char *s) 
{ 
    int key = 0; 
    while (*s) 
     key = key * 37 + *s++; 

    return key; 
} 

int hash_fun(int key, int try, int max) { 
    return (key + try) % max; 
} 

struct hash_table *table; 

int hash_insert(struct hashRow *data, struct hash_table *hash_table) { 
    int try, hash; 
    if(hash_table->number_of_elements < hash_table->max) { 
     return 0; // FULL 
    } 
    for(try = 0; true; try++) { 
    int hkey = hashstring(data->key); 
     hash = hash_fun(hkey, try, hash_table->max); 
     if(hash_table->elements[hash] == 0) { // empty cell 
      hash_table->elements[hash] = data; 
      hash_table->number_of_elements++; 
      return 1; 
     } 
    } 
    return 0; 
} 

struct hashRow *hash_retrieve(char *key, struct hash_table *hash_table) { 
    int try, hash; 
    for(try = 0; true; try++) { 
    int hkey = hashstring(key); 
     hash = hash_fun(hkey, try, hash_table->max); 
     if(hash_table->elements[hash] == 0) { 
      return 0; // Nothing found 
     } 
     if(hash_table->elements[hash]->key == key) { 
      return hash_table->elements[hash]; 
     } 
    } 
    return 0; 
} 


int hash_delete(char *key, struct hash_table *hash_table) { 
    int try, hash; 
    for(try = 0; true; try++) { 
    int hkey = hashstring(key); 
     hash = hash_fun(hkey, try, hash_table->max); 
     if(hash_table->elements[hash] == 0) { 
      return 0; // Nothing found 
     } 
     if(hash_table->elements[hash]->key == key) { 
      hash_table->number_of_elements--; 
      hash_table->elements[hash] = 0; 
      return 1; // Success 
     } 
    } 
    return 0; 
} 

void insertsomething() 
{ 

     struct hashRow *toInsert; 
    toInsert = (struct hashRow *)malloc(sizeof(*toInsert)); 

    printf("toInsert declared\n"); 

    char *k = (char*)malloc(sizeof(char*)); 
    char *v = (char*)malloc(sizeof(char*)); 

    k = "sayhello"; 
    v = "hello"; 

これは私が問題を抱えているようです。struct value = segfaultを設定する

 toInsert->key = k; 
     toInsert->value = v; 

     hash_insert(toInsert, table); 
} 

int main() 
{ 
     printf("calling insertsomething.\n"); 
    insertsomething(); 
    struct hashRow *gotten; 
    gotten = hash_retrieve("sayhello", table); 
    printf("test: %s\n", gotten->value); 
} 

私はハッシュテーブルを作成しようとしていますが、私はそれがセグメンテーション違反toInsert構造体のポインタに値を設定しようとするたびに。誰かが私が間違っていることを私に説明することはできますか?

+0

'' strcpy(k、 "sayhello"); ' –

+1

' char * k =(char *)malloc(sizeof(char *)); 'は十分なスペースを確保していません。 '' sayhello "'を格納します( 'mrloc(strlen(" sayhello ")+ 1)')。 –

+0

私はそれらの両方を試して、運はありません。まだsegの欠陥を取得しています。 –

答えて

2

これを試してください:あなたはhash_tableのためのメモリを確保どこ

void insertsomething() 
{ 
    struct hashRow *toInsert; 
    toInsert = (struct hashRow *)malloc(sizeof(*toInsert)); 

    printf("toInsert declared\n"); 

/* 
    char *k = (char*)malloc(sizeof(char*)); // wrong size 
    char *v = (char*)malloc(sizeof(char*)); // wrong size 

    k = "sayhello"; // bad assignment 
    v = "hello"; // bad assignment 
*/ 

    toInsert->key = strdup("sayhello"); 
    toInsert->value = strdup("hello"); 

    hash_insert(toInsert, table); 
} 

また、私は見つけることができません。どこか他の場所に隠されていますか?

+0

@AaronThomasBlakely次に、ハッシュテーブル用のメモリも割り当てる必要があります。 – shinkou

+0

それはそれかもしれない、私はそれのためのメモリを予約することを忘れた。 –

+0

私はそれを試しています: struct hash_table * table; テーブル=(構造体hash_table *)malloc(sizeof(*テーブル)); しかし、競合するタイプについてはエラーが発生し始めます。 –

関連する問題