选取哈希函数h(k)=(3k)%11

时间: 2023-03-16 13:46:11 浏览: 124
哈希函数h(k)=(3k)%11的意思是将关键字k乘以3,然后对11取余数,得到的余数就是哈希表中的位置。这个哈希函数的特点是简单、快速,适用于关键字分布比较均匀的情况。但是,如果关键字分布不均匀,就可能会出现哈希冲突,影响哈希表的性能。因此,在实际应用中,需要根据具体情况选择合适的哈希函数。
相关问题

选取哈希函数H(k)=(3k)%11,采用开放定址法处理冲突,di=i((7k)%10+1),i=1,2,3,4,...在0-10的散列地址空间中,依次存放如下关键字22,41,53,46,30,13,01,67.请画出最后的哈希表。

首先,我们需要对给定的关键字进行哈希,具体方法是将关键字 k 带入哈希函数 H(k),得到散列地址: - H(22) = (3 * 22) % 11 = 8 - H(41) = (3 * 41) % 11 = 8 - H(53) = (3 * 53) % 11 = 4 - H(46) = (3 * 46) % 11 = 8 - H(30) = (3 * 30) % 11 = 8 - H(13) = (3 * 13) % 11 = 6 - H(01) = (3 * 1) % 11 = 3 - H(67) = (3 * 67) % 11 = 8 我们可以看到,关键字 41、46、30 和 67 都被哈希到了散列地址 8,发生了冲突。因此,我们需要采用开放定址法来处理冲突,具体方法是根据 di 的值依次查找下一个空闲的散列地址,直到找到一个空闲的地址为止。 根据给定的公式 di = i * ((7k % 10) + 1),可以计算出每个关键字的 di 值: - d22 = 1 - d41 = 2 - d53 = 3 - d46 = 4 - d30 = 5 - d13 = 6 - d01 = 7 - d67 = 8 接下来,我们可以依次将关键字存放到散列表中,具体过程如下: 1. 将关键字 22 存放到散列地址 8 中。 2. 将关键字 41 存放到散列地址 9 中。 3. 将关键字 53 存放到散列地址 4 中。 4. 将关键字 46 存放到散列地址 0 中。 5. 将关键字 30 存放到散列地址 2 中。 6. 将关键字 13 存放到散列地址 6 中。 7. 将关键字 01 存放到散列地址 3 中。 8. 将关键字 67 存放到散列地址 1 中。 最终哈希表的状态如下: |散列地址|关键字| |--------|------| |0 |46 | |1 |67 | |2 |30 | |3 |01 | |4 |53 | |5 | | |6 |13 | |7 | | |8 |22 | |9 |41 | |10 | |

选取哈希函数H(k)=(3k) MOD 11。用开放定址法处理冲突,di= i((7k) MOD 10+1) (i=1,2,3, …)。试在0~10的散列地址空间中对关键字序列(22, 41, 53, 46, 30, 13, 01, 67)造哈希表,并求等概率情况下查找成功时的平均查找长度

按照哈希函数H(k)=(3k) MOD 11,可以得到关键字对应的散列地址如下: - H(22) = 2 - H(41) = 7 - H(53) = 8 - H(46) = 7(冲突) - H(30) = 9 - H(13) = 6 - H(01) = 3 - H(67) = 10 由于关键字46和关键字41的散列地址相同,因此需要处理冲突。按照开放定址法,可以得到它们的探测序列如下: - d1(46) = 8 - d2(46) = 10 - d3(46) = 2 - d4(46) = 4 - d5(46) = 6 - d6(46) = 9 - d7(46) = 1 - d1(41) = 5 - d2(41) = 7 - d3(41) = 9 - d4(41) = 1 - d5(41) = 3 - d6(41) = 6 - d7(41) = 8 最终得到的哈希表如下: | 散列地址 | 关键字 | | ------- | ------ | | 0 | | | 1 | 67 | | 2 | 22 | | 3 | 01 | | 4 | 46 | | 5 | 41 | | 6 | 13 | | 7 | 41 | | 8 | 53 | | 9 | 30 | | 10 | | 等概率情况下查找成功时的平均查找长度ASL可以通过以下公式计算: ASL = (p1 * 1) + (p2 * 2) + ... + (pi * i) 其中pi表示表中有i个关键字的概率。在本题中,共有8个关键字,因此pi的取值如下: - p0 = 0.25(0个关键字的概率) - p1 = 0.25(1个关键字的概率) - p2 = 0.25(2个关键字的概率) - p3 = 0.125(3个关键字的概率) - p4 = 0.0625(4个关键字的概率) - p5 = 0.03125(5个关键字的概率) - p6 = 0.015625(6个关键字的概率) - p7 = 0.015625(7个关键字的概率) 根据散列表中各关键字的探测序列,可以得到每个关键字在表中的位置和需要比较的次数,如下: - 22:2(1次比较) - 41:5(1次比较) - 53:8(1次比较) - 46:4(6次比较) - 30:9(1次比较) - 13:6(1次比较) - 01:3(1次比较) - 67:1(1次比较) 因此,ASL的计算如下: ASL = (0.25 * 0) + (0.25 * 1) + (0.25 * 2) + (0.125 * 3) + (0.0625 * 4) + (0.03125 * 5) + (0.015625 * 6) + (0.015625 * 7) = 2.546875 因此,等概率情况下查找成功时的平均查找长度ASL为2.546875。

相关推荐

最新推荐

recommend-type

数据结构(查找)习题及答案

3、设哈希表L长m=14,哈希函数H(key)=key%11,表中已...... ........ 五、设有3阶B-树如下,画出删除关键字值17的过程。   六、设哈希函数H(key)=key%13,用公共溢出区法处理冲突。试在0~19的散列地址...
recommend-type

Python学习笔记16 - 猜数字小游戏

猜数字小游戏的相关函数,与主程序搭配使用
recommend-type

机器人比赛内容的讲解,帮助简单了解一下机器人比赛的注意事项

适用于未参加过机器人比赛的小伙伴,简单了解一下注意事项。
recommend-type

shumaguan.rar

shumaguan.rar
recommend-type

信捷MP3系列步进电机CAD图纸.zip

信捷MP3系列步进电机CAD图纸
recommend-type

BSC绩效考核指标汇总 (2).docx

BSC(Balanced Scorecard,平衡计分卡)是一种战略绩效管理系统,它将企业的绩效评估从传统的财务维度扩展到非财务领域,以提供更全面、深入的业绩衡量。在提供的文档中,BSC绩效考核指标主要分为两大类:财务类和客户类。 1. 财务类指标: - 部门费用的实际与预算比较:如项目研究开发费用、课题费用、招聘费用、培训费用和新产品研发费用,均通过实际支出与计划预算的百分比来衡量,这反映了部门在成本控制上的效率。 - 经营利润指标:如承保利润、赔付率和理赔统计,这些涉及保险公司的核心盈利能力和风险管理水平。 - 人力成本和保费收益:如人力成本与计划的比例,以及标准保费、附加佣金、续期推动费用等与预算的对比,评估业务运营和盈利能力。 - 财务效率:包括管理费用、销售费用和投资回报率,如净投资收益率、销售目标达成率等,反映公司的财务健康状况和经营效率。 2. 客户类指标: - 客户满意度:通过包装水平客户满意度调研,了解产品和服务的质量和客户体验。 - 市场表现:通过市场销售月报和市场份额,衡量公司在市场中的竞争地位和销售业绩。 - 服务指标:如新契约标保完成度、续保率和出租率,体现客户服务质量和客户忠诚度。 - 品牌和市场知名度:通过问卷调查、公众媒体反馈和总公司级评价来评估品牌影响力和市场认知度。 BSC绩效考核指标旨在确保企业的战略目标与财务和非财务目标的平衡,通过量化这些关键指标,帮助管理层做出决策,优化资源配置,并驱动组织的整体业绩提升。同时,这份指标汇总文档强调了财务稳健性和客户满意度的重要性,体现了现代企业对多维度绩效管理的重视。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【进阶】Flask中的会话与用户管理

![python网络编程合集](https://media.geeksforgeeks.org/wp-content/uploads/20201021201514/pythonrequests.PNG) # 2.1 用户注册和登录 ### 2.1.1 用户注册表单的设计和验证 用户注册表单是用户创建帐户的第一步,因此至关重要。它应该简单易用,同时收集必要的用户信息。 * **字段设计:**表单应包含必要的字段,如用户名、电子邮件和密码。 * **验证:**表单应验证字段的格式和有效性,例如电子邮件地址的格式和密码的强度。 * **错误处理:**表单应优雅地处理验证错误,并提供清晰的错误消
recommend-type

卷积神经网络实现手势识别程序

卷积神经网络(Convolutional Neural Network, CNN)在手势识别中是一种非常有效的机器学习模型。CNN特别适用于处理图像数据,因为它能够自动提取和学习局部特征,这对于像手势这样的空间模式识别非常重要。以下是使用CNN实现手势识别的基本步骤: 1. **输入数据准备**:首先,你需要收集或获取一组带有标签的手势图像,作为训练和测试数据集。 2. **数据预处理**:对图像进行标准化、裁剪、大小调整等操作,以便于网络输入。 3. **卷积层(Convolutional Layer)**:这是CNN的核心部分,通过一系列可学习的滤波器(卷积核)对输入图像进行卷积,以
recommend-type

BSC资料.pdf

"BSC资料.pdf" 战略地图是一种战略管理工具,它帮助企业将战略目标可视化,确保所有部门和员工的工作都与公司的整体战略方向保持一致。战略地图的核心内容包括四个相互关联的视角:财务、客户、内部流程和学习与成长。 1. **财务视角**:这是战略地图的最终目标,通常表现为股东价值的提升。例如,股东期望五年后的销售收入达到五亿元,而目前只有一亿元,那么四亿元的差距就是企业的总体目标。 2. **客户视角**:为了实现财务目标,需要明确客户价值主张。企业可以通过提供最低总成本、产品创新、全面解决方案或系统锁定等方式吸引和保留客户,以实现销售额的增长。 3. **内部流程视角**:确定关键流程以支持客户价值主张和财务目标的实现。主要流程可能包括运营管理、客户管理、创新和社会责任等,每个流程都需要有明确的短期、中期和长期目标。 4. **学习与成长视角**:评估和提升企业的人力资本、信息资本和组织资本,确保这些无形资产能够支持内部流程的优化和战略目标的达成。 绘制战略地图的六个步骤: 1. **确定股东价值差距**:识别与股东期望之间的差距。 2. **调整客户价值主张**:分析客户并调整策略以满足他们的需求。 3. **设定价值提升时间表**:规划各阶段的目标以逐步缩小差距。 4. **确定战略主题**:识别关键内部流程并设定目标。 5. **提升战略准备度**:评估并提升无形资产的战略准备度。 6. **制定行动方案**:根据战略地图制定具体行动计划,分配资源和预算。 战略地图的有效性主要取决于两个要素: 1. **KPI的数量及分布比例**:一个有效的战略地图通常包含20个左右的指标,且在四个视角之间有均衡的分布,如财务20%,客户20%,内部流程40%。 2. **KPI的性质比例**:指标应涵盖财务、客户、内部流程和学习与成长等各个方面,以全面反映组织的绩效。 战略地图不仅帮助管理层清晰传达战略意图,也使员工能更好地理解自己的工作如何对公司整体目标产生贡献,从而提高执行力和组织协同性。