什么是最快的重播方式?

时间:2016-04-08 01:23:09

标签: c++ data-structures hashtable

来自Mark Weiss的C ++数据结构和算法分析:

/**
* Rehashing for quadratic probing hash table.
*/
void rehash( )
{
    vector<HashEntry> oldArray = array;

    // Create new double-sized, empty table
    array.resize( nextPrime( 2 * oldArray.size( ) ) );
    for( auto & entry : array )
        entry.info = EMPTY;

    // Copy table over
    currentSize = 0;
    for( auto & entry : oldArray )
        if( entry.info == ACTIVE )
            insert( std::move( entry.element ) );
}

这似乎是一个非常痛苦的操作,必须通过表中的每个元素,并检查元素是否处于活动状态。特别是,是否有一个实现仅仅意味着要插入的元素数量(而不是整个表格)?

1 个答案:

答案 0 :(得分:0)

参见Per-Ake Larson, Dynamic Hashing, CACM 1988年4月,第446-457页。他描述了一个散列系统,其中可以拆分存储桶,只需要重新计算拆分存储桶的哈希码。

您将在1998年7月的Usenet comp.sources.misc档案中找到'C' version of it coded as an hsearch(3) replacement,由ejp@ausmelb.oz(我)提供。此代码随后进入Berkeley DB以及包括OpenLDAP在内的其他各个地方。抱歉,我还没有原始的源代码,但我确实有Java实现。