C 字典实现

本文介绍了如何在C语言中实现一个简单的字典数据结构,包括哈希表的定义、哈希函数、查找和安装功能。此外,还提供了字典操作的接口,如插入键值对和获取键对应的值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/////////// C dictionary  data structure ////////////


struct nlist { /* table entry: */

    struct nlist *next; /* next entry in chain */

    char *name; /* defined name */

    char *defn; /* replacement text */

};


#define HASHSIZE 101

static struct nlist *hashtab[HASHSIZE]; /* pointer table */


/* hash: form hash value for string s */

unsigned hash(char *s)

{

    unsigned hashval;

    for (hashval = 0; *s != '\0'; s++)

        hashval = *s + 31 * hashval;

    return hashval % HASHSIZE;

}


/* lookup: look for s in hashtab */

struct nlist *lookup(char *s)

{

    struct nlist *np;

    for (np = hashtab[hash(s)]; np != NULL; np = np->next)

        if (strcmp(s, np->name) == 0)

            return np; /* found */

    return NULL; /* not found */

}


char *strdup(char *);

/* install: put (name, defn) in hashtab */

struct nlist *install(char *name, char *defn)

{

    struct nlist *np;

    unsigned hashval;

    if ((np = lookup(name)) == NULL) { /* not found */

        np = (struct nlist *) malloc(sizeof(*np));

        if (np == NULL || (np->name = strdup(name)) == NULL)

            return NULL;

        hashval = hash(name);

        np->next = hashtab[hashval];

        hashtab[hashval] = np;

    } else /* already there */

        free((void *) np->defn); /*free previous defn */

    if ((np->defn = strdup(defn)) == NULL)

        return NULL;

    return np;

}


char *strdup(char *s) /* make a duplicate of s */

{

    char *p;

    p = (char *) malloc(strlen(s)+1); /* +1 for ’\0’ */

    if (p != NULL)

        strcpy(p, s);

    return p;

}


/*dic opreation interface */

void dic_put(char *key, char *value)

{

    install(key,value);

}


char* dic_value_for_key(char *key)

{

    char *ret = "";

    struct nlist *np = lookup(key);

    if (np != NULL) {

        ret = np->defn;

    } 

    return ret;

}


/////////// C dictionary  data structure end ////////////


============= 调用例子 =================

dic_put("1", "Hello");

printf("value ====>> %s\n", dic_value_for_key("1"));

输出:

value ====>> Hello

=======================================

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值