#include <hash_set>
#include <iostream>
using namespace std;
int main()
{
hashtable<int,
int,
hash<int>,
identify<int>,
equal_to<int>,
alloc> iht(,hash<int>,equal_to<int>()); //指定保留50个bucket(桶)
cout<<iht.size()<<endl; //
cout<<iht.bucket_count()<<endl; //53这是STL提供的最小质数
cout<<iht.max_bucket_count()<<endl; // iht.insert_unique();
iht.insert_unique();
iht.insert_unique();
iht.insert_unique();
iht.insert_unique();
iht.insert_unique();
cout<<iht.size()<<endl; //6,此即hashtable<T>::num_elements /*一下声明一个hashtable迭代器*/
hashtable<int,
int,
hash<int>,
identify<int>,
equal_to<int>,
alloc>::iterator ite = iht.begin(); for(int i = ;i<iht.size();i++,ite++)
cout<< *ite<<<' '; //输出:53 55 2 108 59 63 并没有顺序
cout<<endl; /*遍历所有buckets,如果其节点个数不为0,就打印节点个数,为0不打印*/
for(int i = ;i<iht.bucket_count();i++)
{
int n = iht.elem_in_bucket(i);
if(n!=)
cout<<"bucket["<<i<<"] has"<<n<<" elems."<<endl;
}
/*
输出:
bucket[0] has 1 elems.
bucket[2] has 3 elems.
bucket[6] has 1 elems.
bucket[10] has 1 elems.
*/ /*为了验证“bucket(list)”的容量就是buckets vector的大小(这是从
hashtable<T>::resize()得知的结果),我刻意将元素加到54个,
看看是否发生重建表*/ for(int i = ;i<;i++)
iht.insert_equal(i);
cout<<iht.size()<<endl; //
cout<<iht.buck_count()<<endl; //97确实扩容了(重建) for (inti; i<iht.bucket_count();i++ )
{
int n = iht.elems_in_bucket(i);
if(n!=)
cout<<"bucket["<<i<<"] has"<<n<<" elems."<<endl;
}
/*打印的结果
bucket[2]到bucket[11]的节点个数为2
其余的bucket[0]~bucket[47]的节点个数为1
此外,bucket[53],[55],[59],[63]的节点个数均为1*/ /*以迭代器变量hashtable,将所有节点打印出来*/
ite = iht.begin();
for(int i = ;i<iht.size();i++,ite++)
cout<< *ite<<<' ';
cout<<endl; cout<<*(iht.find())<<endl;//
cout<<iht.count()<<endl;//
return ;
}

hashtable的运用实例的更多相关文章

  1. C# 哈希表(Hashtable)用法笔记

    一.什么是Hashtable? Hashtable 类代表了一系列基于键的哈希代码组织起来的键/值对.它使用键来访问集合中的元素. 当您使用键访问元素时,则使用哈希表,而且您可以识别一个有用的键值.哈 ...

  2. HashTable类

    HashTable类不紧可以像Vector类一样动态的存储一系列的对象,而且对存储的每一个对象(称为值)都安排另一个对象(称为关键字)与它相关联. 用做关键字的类必须覆盖Object.hashCode ...

  3. ASP.NET 缓存技术分析

    缓存功能是大型网站设计一个很重要的部分.由数据库驱动的Web应用程序,如果需要改善其性能,最好的方法是使用缓存功能.可能的情况下尽量使用缓存,从内存中返回数据的速度始终比去数据库查的速度快,因而可以大 ...

  4. ASP.NET Cache

    ASP.NET为了方便我们访问Cache,在HttpRuntime类中加了一个静态属性Cache,这样,我们就可以在任意地方使用Cache的功能. 而且,ASP.NET还给它增加了二个“快捷方式”:P ...

  5. 细说 ASP.NET Cache 及其高级用法

    许多做过程序性能优化的人,或者关注过程程序性能的人,应该都使用过各类缓存技术. 而我今天所说的Cache是专指ASP.NET的Cache,我们可以使用HttpRuntime.Cache访问到的那个Ca ...

  6. Log4net 配置注意事项

    1. 首先引入Log4net程序集 2.修改webconfig配置文件 在 configuration 节点下面添加如下节点 <configSections> <section na ...

  7. 细说 ASP.NET Cache 及其高级用法【转】

    阅读目录 开始 Cache的基本用途 Cache的定义 Cache常见用法 Cache类的特点 缓存项的过期时间 缓存项的依赖关系 - 依赖其它缓存项 缓存项的依赖关系 - 文件依赖 缓存项的移除优先 ...

  8. C#基础复习(4) 之 浅析List、Dictionary

    参考资料 [1] .netCore 源码 https://github.com/dotnet/corefx [2] <Unity 3D脚本编程 使用C#语言开发跨平台游戏>陈嘉栋著 [3] ...

  9. [转]细说 ASP.NET Cache 及其高级用法

    本文转自:http://www.cnblogs.com/fish-li/archive/2011/12/27/2304063.html 阅读目录 开始 Cache的基本用途 Cache的定义 Cach ...

随机推荐

  1. jQuery事件 (jQuery实现图片轮播)

    jQuery事件按执行时间,主要分为两种,第一种是在网页加载完执行,第二种绑定在元素中,由访问者某些行为触发. $(document).ready(function(){ //事件 }); $(&qu ...

  2. 【转】Linux方向职业分析

    引言: 据了解,Linux普通网络管理人员的月薪大约5000元左右,负责编程的Linux软件工程师月薪大约在8000元到12000元之间,Linux嵌入式软件开发人员的月薪大约在12000元以上. 影 ...

  3. Win10下通过IIS调试ASP程序遇到的问题和解决方案

    最近维护了以前别人的写的一个ASP的系统,记录一下调试过程中的问题和解决方案. 环境篇 万维网发布服务(W3SVC)已经停止 问题: 万维网发布服务(W3SVC)已经停止.除非万维网发布服务(W3SV ...

  4. SpringMVC 参数绑定注解解析

    本文介绍了用于参数绑定的相关注解. 绑定:将请求中的字段按照名字匹配的原则填入模型对象. SpringMVC就跟Struts2一样,通过拦截器进行参数匹配. 代码在 https://github.co ...

  5. [DeeplearningAI笔记]ML strategy_1_3可避免误差与改善模型方法

    机器学习策略 ML strategy 觉得有用的话,欢迎一起讨论相互学习~Follow Me 1.8 为什么是人的表现 今天,机器学习算法可以与人类水平的表现性能竞争,因为它们在很多应用程序中更有生产 ...

  6. python中的time模块

    time模块--时间获取和转换 time模块提供各种时间相关的功能 与时间相关的模块有:time,datetime,calendar 必要说明: 这个模块的功能不是适用于所有的平台 这个模块中定义的大 ...

  7. HBase Filter及对应Shell--转

    http://www.cnblogs.com/skyl/p/4807793.html 比较运算符 CompareFilter.CompareOp比较运算符用于定义比较关系,可以有以下几类值供选择: E ...

  8. E 洛谷 P3598 Koishi Loves Number Theory[数论]

    题目描述 Koishi十分喜欢数论. 她的朋友Flandre为了检测她和数论是不是真爱,给了她一个问题. 已知 给定和个数,求对取模. 按照套路,呆萌的Koishi当然假装不会做了,于是她来向你请教这 ...

  9. market1501的学习,跟着苏同学的博客学习

    先看看官方文档:然后附上苏的博客链接http://bigbrothersue.com/index.php/2017/12/20/person-re-id/ The Market-1501 datase ...

  10. 【学习笔记】Hibernate 注解 (Y2-1-9)

    Hibernate注解 1.什么是注解在类上或者方法上打上其他类型的类型元数据 @标志 使用过的注解: @override  方法重写 @Test Junit 单元测试 @Before 单元测试 @A ...