A Simple Hash Class(one)

 

/*
  Name: hash class
  Copyright: all right reserved @ lizuding@gmail.com
  Author: lizuding@gmail.com
  Date: 23-01-08 14:25
  Description: hash class
*/


class  Hash
{
public:
    Hash();
    
~Hash();
    
void add(string key);
    
int find(string key); 
       
protected:
    
static const int DEFAULT_SIZE = 10;
    
int hash(const string & key);
    
int rehash(const int pseudo_pos);
    
private:
    
string *m_pData;   
}
;

Hash::Hash() 

    m_pData 
= new string[DEFAULT_SIZE];     
    
    
for (int i = 0; i < DEFAULT_SIZE; ++ i) 
        m_pData[i] 
= "";
}


Hash::
~ Hash()  { delete[] m_pData; }

void  Hash::add( string  key)  {
    
int pos = hash(key);    
    
if ( m_pData[pos] != "" ) 
        pos 
= rehash(pos);
    m_pData[pos] 
= key;
}


int  Hash::find( string  key)  {
    
int pos = hash(key);    
    
while ( m_pData[pos] != key )
        pos 
= ++pos % DEFAULT_SIZE;
        
    
return pos;
}
    

int  Hash::hash( const   string   &  key) 
    
return key.c_str()[0- 'A'
}
  

int  Hash::rehash( int  pseudo_pos)  {
    
do {
        pseudo_pos 
= ++ pseudo_pos %  DEFAULT_SIZE;
    }
while (m_pData[pseudo_pos] != "");
    
    
return pseudo_pos;
}
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值