hash_set是以hashtable为底层机制。所以hash_set所供应的操作接口hashtable都
提供了,所以几乎所有的hash_set操作行为,都只是转调用hashtable的操作而已
RB-tree有自动排序功能,但是hashtable没有,相应的hashset也没有
set不像map那样可以同时拥有实值value和键值key,set元素的键值就是实值,实值就是键值
set的元素有自动排序功能,但是hash_set没有
template <class Value,class HashFcn=hash<Value>,
class EqualKey=equal_to<Value>,class Alloc=alloc>
class hash_set{
private:
//以下使用的identity<>定义于<stl_function.h>中
typedef hashtable<Value,Value,HashFcn,identity<Value>,EqualKey Alloc>ht;
ht rep;//底层机制以hash table完成
public:
typedef typename ht::key_type key_type;
typedef typename ht::value_type value_type;
typedef typename ht::hasher hasher;
typedef typename ht::key_equal key_equal;
typedef typename ht::size_type size_type;
typedef typename ht::difference_type difference_type;
typedef typename ht::const_pointer pointer;
typedef typename ht::const_Pointer const_pointer;
typedef typename ht::const_reference reference;
typedef typename ht::const_reference const_reference;
typedef typename ht::const_iterator iterator;
typedef typename ht::const_iterator const_iterator;
hasher hash_funct()const{return rep.hash_funct();}
key_equal key_eq() const{return rep.key_eq();}
public:
//缺省使用大小为100的表格,将被hash table调整为最接近且较大的质数
hash_set():rep(100,hasher(),key_equal()){}
explicit hash_set(size_type n):rep(n,hf,key_equal()){}
hash_set(size_type n,const hasher&hf,const key_equal&eql):rep(n,hf,eql){}
//以下,插入操作全部使用insert_unique(),不允许键值重复
template<class InpuIterator>
hash_set(InputIterator f,InputIterator l):rep(100,hasher(),key_equal()){rep.insert_unique(f,l);}
template<class InputIterator>
hash_set(InputIterator f,InputIterator l,size_type n,const hasher&hf):rep(n,hf,key_equal()){rep.insert_unique(f,l);}
template<class InputIterator>
hash_set(InputIterator f,InputIterator l,size_type n,const hasher&hfmconst key_equal&eql):rep(n,hf,eql){rep.insert_unique(f,l);}
public:
//所有操作几乎都有hash table的对应版本,传递调用就可以了
size_type size()const{return rep.size();}
size_type max_size()const{return rep.max_size();}
bool empty()const{return rep.empty();}
void swap(hash_set &hs){rep.swap(hs.rep);}
friend bool operator==__STL_NULL_TMPL_ARGS(const hash_set&,const hash_set&);
iterator begin()const{return rep.begin();}
iterator end()const{return rep.end();}
public:
pair<iterator,bool>insert(const value_type&obj){
pair<typename ht::iterator,bool>p=rep.insert_unique(obj);
return pair<iterator,bool>(p.first,p.second);
}
template <class InputIterator>
void insert(InputIterator f,InputIterator l){rep.insert_unique(f,l);}
pair<iterator,bool>insert_noresize(const value_type&obj){
pair<typename ht::iterator,bool>p=rep.insert_unique_noresize(obj);
return pair<iterator,bool>(p.first,p.second);
}
iterator find(const key_type&key)const{return rep.find(key);}
size_type count(const key_type&key)const {return rep.count(key);}
pair<iterator,iterator>equal_range(const key_type&key)const{
return rep.equal_range(key);
}
size_type erase(const key_type&key){return rep.erase(key);}
void erase(iterator it){rep.erase(it);}
void erase(iterator f,iterator l){rep.erase(f,l);}
void clear(){rep.clear();}
public:
void resize(size_type hint){rep.resize(hint);}
size_type bucket_count()const{return rep.bucket_count();}
size_type max_bucket_count()const{return rep.max_bucket_count();}
size_type elems_in_bucket(size_type n)const
{
return rep.elems_in_bucket(n);
};
template <class Value,class HashFcn,class EqualKey,class Alloc>
inline bool operator==(const hash_set<Value,HashFcn,EqualKey,Alloc>&hsl,const hash_Set<Value,HashFcn,EqualKey,Alloc>&hs2){
return hs1.rep==hs2.rep;
}
}
下面给出一个测试实例
#include<iostream>
#include<hash_set>
#include<cstring>
using namespace std;
struct eqstr{
bool operator()(const char*s1,const char *s2)const{
return strcmp(s1,s2)==0;
}
};
void lookup(const hash_set<const char*,hash<const char*>,eqstr>&Set,const char*word)
{
hash_set<const char*,hash<const char*>,eqstr>::const_iterator it=Set.find(word);
cout<<" "<<word<<" :"<<(it!=Set.end()?"present":"not present")<<endl;
}
int main(){
hash_set<const char*,hash<const char*>,eqstr>Set;
Set.insert("kiwi");
Set.insert("plum");
Set.insert("apple");
Set.insert("mango");
Set.insert("apricot");
Set.insert("banana");
lookup(Set,"mango");
lookup(Set,"apple");
lookup(Set,"durian");
hash_set<>const char*,hash<const char*>,eqstr>::iterator ite1=Set.begin();
hash_set<>const char*,hash<const char*>,eqstr>::iterator ite2=Set.end();
for(;ite1!=ite2;++ite1)
cout<<*ite1<<' ';//
return 0;
}
475

被折叠的 条评论
为什么被折叠?



