首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在哈希表中将存储桶标记为已删除

在哈希表中将存储桶标记为已删除
EN

Stack Overflow用户
提问于 2017-03-26 11:25:58
回答 1查看 123关注 0票数 0

我一直在为这件事找一个像样的解释。我正在使用C++编写一个线性探测哈希表,但是我在使用remove()操作时遇到了问题。我正在散列strings的字典集合,我想知道如何将索引i remove from设置为deleted,这样search()insert()才能正常工作。任何帮助/伪代码都会很棒,谢谢。我现在最好的猜测是创建一个名为deleted的结构对象,并将其放在那里。

EN

回答 1

Stack Overflow用户

发布于 2017-03-26 12:26:05

每个存储桶可以是一个包含键、值和指示存储桶是否为空的标志的struct,如下所示:

代码语言:javascript
复制
struct bucket
{
    std::string key;
    std::string value;
    bool empty = true;
};

然后你就可以拥有这样一个存储桶的std::vector了:

代码语言:javascript
复制
class hash_table
{
public:
    hash_table(): buckets(100) {} // hash table has 100 buckets

    void put(std::string const& key, std::string const& value)
    {
        // ...
    }

    // etc...

private:
    std::vector<bucket> buckets; // the table
};
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43024643

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档