news 2026/4/28 3:05:37

PAT 1145 Hashing - Average Search Time

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PAT 1145 Hashing - Average Search Time



这一题的大意是给出一个哈希表的大小,如果不是质数,就把它变成和它最近的大的质数。
然后给出N个数,把这N个数插入到哈希表中,如果不能插入输出:x cannot be inserted.
然后给出M个数,判断它们在不在哈希表中,并且统计找到它们需要查询的次数的平均值。
当出现哈希冲突的时候,采用平方探测法
这一题我们只需要清楚平方探测法就好写,剩下就是模拟哈希表的过程。
平方探测法:

for(intk=0;k<msize;k++){if(hash[(x+k*k)%msize]==x){cnt++;returncnt;}elseif(hash[(x+k*k)%msize]==0){cnt++;returncnt;}else{cnt++;}}

就是加上一个k*k的平方。
最终的代码按题意模拟即可:
完整代码如下:

#include<bits/stdc++.h>#include<iostream>usingnamespacestd;intMSize;intN;intM;boolisprime(intx){if(x==0||x==1){returnfalse;}if(x==2){returntrue;}for(inti=2;i<sqrt(x)+1;i++){if(x%i==0){returnfalse;}}returntrue;}intprime(intx){if(isprime(x)){returnx;}else{//找离x最近的质数for(inti=x+1;i<=1e5;i++){if(isprime(i)){returni;}}}}intquery(intx,intmsize,inthash[]){intcnt=0;for(intk=0;k<msize;k++){if(hash[(x+k*k)%msize]==x){cnt++;returncnt;}elseif(hash[(x+k*k)%msize]==0){cnt++;returncnt;}else{cnt++;}}if(cnt==msize){returncnt+1;}if(cnt==0){return0;}}intmain(){cin>>MSize>>N>>M;intmsize=prime(MSize);//因此哈希表的大小是5inthash[msize];memset(hash,0,sizeof(hash));for(inti=0;i<N;i++){intkey;cin>>key;if(hash[key%msize]==0){hash[key%msize]=key;}else{//说明发生哈希碰撞intk=1;boolflag=0;while(hash[(key+k*k)%msize]!=0){if(k>=msize){flag=1;break;}k++;}if(flag==1){cout<<key<<" cannot be inserted."<<endl;}else{hash[(key+k*k)%msize]=key;}}}intans=0;for(inti=0;i<M;i++){intx;cin>>x;intt=query(x,msize,hash);ans+=t;}printf("%.1f\n",(double)ans/M);return0;}

注意如果查找某一个值的时候,发现在哈希表中的位置为空,说明这个值不在哈希表中,如果查询了所有可能的值,但仍然没有查到某一个元素,那么查询次数应该是哈希表大小+1.

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/25 13:51:15

AutoGPT文件操作功能详解:自动创建、读取、修改本地数据

AutoGPT文件操作功能详解&#xff1a;自动创建、读取、修改本地数据 在构建真正意义上的“自主AI助手”这条路上&#xff0c;一个常被低估但至关重要的能力浮出水面——对本地文件的自主读写与管理。我们早已习惯让AI回答问题、生成文案&#xff0c;但如果它做完就忘了呢&#…

作者头像 李华
网站建设 2026/4/18 18:00:46

如何实现设备运维的智能化转型?从预测性维护到数字孪生全解析

在工业4.0与智能制造加速推进的背景下&#xff0c;设备运维已不再是传统意义上“出了故障才修”的应急操作&#xff0c;而是演变为驱动制造企业降本增效、实现数字化转型的核心引擎。现代设备运维正经历一场由数据、AI与全链协同重构的深刻变革——从依赖人工经验的点巡检&…

作者头像 李华
网站建设 2026/4/23 10:27:08

树控件、下拉框、文本框常用测试用例

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 01 控件的测试外观操作 1&#xff09;项目中的所有树是否风格一致 2&#xff09;树结构的默认状态是怎样的。比如默认树是否是展开&#xff0c;是展开几级&#…

作者头像 李华
网站建设 2026/4/25 15:20:02

物理神经网络如何与大模型结合

物理神经网络&#xff08;Physics-Informed Neural Networks, PINNs&#xff09;与大模型&#xff08;如大型语言模型 LLMs 或视觉大模型&#xff09;的结合&#xff0c;是近年来人工智能与科学计算交叉领域的一个前沿方向。这种融合旨在利用大模型的通用表征能力与物理神经网络…

作者头像 李华
网站建设 2026/4/24 17:44:44

18、RRDTool与NagiosGraph:数据可视化与监控的完美搭档

RRDTool与NagiosGraph:数据可视化与监控的完美搭档 1. RRDTool数据可视化基础 RRDTool是一款强大的工具,它能够自动返回尽可能高分辨率的数据。在进行数据绘图时,不同时间范围的数据会呈现不同的分辨率: - 当绘制一个月以内的数据时,RRDTool返回原始数据,因此能得到高…

作者头像 李华
网站建设 2026/4/26 14:09:20

【无标题】网络数据的嗅探与欺骗

一.使用TcpDump分析网络数据TcpDump是KaliLinux下的命令行抓包工具&#xff0c;核心操作&#xff1a;启动工具&#xff1a;直接在终端输入tcpdump即可启动&#xff1b;仅抓包不存储&#xff1a;执行tcpdump&#xff08;默认实时显示抓包结果&#xff0c;不保存到文件&#xff0…

作者头像 李华