题目

The task of this problem is simple: insert a sequence of distinct positive integers into a hash table first.Then try to find another sequence of integer keys from the table and output the average search time (the number of comparisons made to find whether or not the key is in the table). The hash function is defined to be “H(key) = key % TSize” where TSize is the maximum size of the hash table. Quadratic probing (with positive increments only) is used to solve the collisions.

Note that the table size is better to be prime. If the maximum size given by the user is not prime, you must re-define the table size to be the smallest prime number which is larger than the size given by the user.

Input Specification:

Each input file contains one test case. For each case, the first line contains two positive numbers: MSize, N, and M, which are the user-defined table size, the number of input numbers, and the number of keys to be found, respectively. All the three numbers are no more than 104. Then N distinct positive integers are given in the next line. All the numbers in a line are separated by a space and are no more than 105.

Output Specification:

For each test case, in case it is impossible to insert some number, print in a line “X cannot be inserted.”where X is the input number. Finally print in a line the average search time for all the M keys, accurate up to 1 decimal place.

Sample Input:

4 5 4

10 6 4 15 11

11 4 15 2

Sample Output:

15 cannot be inserted.

2.8

题目分析

  1. 如果输入的hash table的大小MS不是质数,需要找到不小于MS的最小质数
  2. 将输入的一系列数散列存放于hash表,使用二次探测解决hash冲突,hash函数为H(key)=(key+step*step)%TSize,若不可插入,打印"X cannot be inserted"
  3. 再输入一系列数,在hash表中查找其是否存在,统计平均查找时间(=平均查找长度),并打印

解题思路

  1. 二次探测散列存储元素于hash表中
  2. 二次探测在hash表中查找输入数字,记录总查找长度求平均值

知识点

  1. 二次探测
int step=0;
while(step<MS&&hash[(key+step*step)%MS]!=key&&hash[(key+step*step)%MS]!=0)step++; //二次探测

易错点

  1. 二次探测在hash表中查找输入数字时,特殊情况-数字在hash表中查找不到时step会一直探测到MS而不是MS-1(为了与另外一种情况区分:step探测到MS-1时探测成功(即:要查找的元素存储于H(key)=(key+(MS-1)*(MS-1))%Tsize的位置))

Code

Code 01

#include <iostream>
using namespace std;
bool isPrime(int num) {
if(num==1)return false;
for(int i=2; i*i<=num; i++) {
if(num%i==0)return false;
}
return true;
}
int main(int argc, char * argv[]) {
int MS,N,M,key;
scanf("%d %d %d",&MS,&N,&M);
while(!isPrime(MS))MS++; //size 若不是质数,重置为质数
int hash[MS]= {0};
for(int i=0; i<N; i++) {
scanf("%d",&key);
int step=0;
while(step<MS&&hash[(key+step*step)%MS]!=0)step++; //二次探测
if(step==MS)printf("%d cannot be inserted.\n", key); //不可插入
else hash[(key+step*step)%MS]=key; //可插入
}
double ans=0;
//第一个点测试错误,第一次遇到打印结果完全一样,但是不通过的情况
for(int i=0; i<M; i++) {
scanf("%d", &key);
int step=0;
while(step<MS&&hash[(key+step*step)%MS]!=key&&hash[(key+step*step)%MS]!=0)step++; //二次探测
ans+=(step+1); //如果hash(key)正好命中,比较次数为0+1;如果需要二次探测,比较次数=step+1;如果是二次探测找不到的情况,比较次数=MS+1与临界step=MS-1时探测到的情况做区分
}
printf("%.1f", ans/(M*1.0));
return 0;
}

PAT Advanced 1145 Hashing – Average Search Time (25) [哈希映射,哈希表,平⽅探测法]的更多相关文章

  1. PAT 甲级 1145 Hashing - Average Search Time (25 分)(读不懂题,也没听说过平方探测法解决哈希冲突。。。感觉题目也有点问题)

    1145 Hashing - Average Search Time (25 分)   The task of this problem is simple: insert a sequence of ...

  2. PAT 甲级 1145 Hashing - Average Search Time

    https://pintia.cn/problem-sets/994805342720868352/problems/994805343236767744 The task of this probl ...

  3. 1145. Hashing - Average Search Time (25)

    The task of this problem is simple: insert a sequence of distinct positive integers into a hash tabl ...

  4. [PAT] 1143 Lowest Common Ancestor(30 分)1145 Hashing - Average Search Time(25 分)

    1145 Hashing - Average Search Time(25 分)The task of this problem is simple: insert a sequence of dis ...

  5. PAT 1145 Hashing - Average Search Time [hash][难]

    1145 Hashing - Average Search Time (25 分) The task of this problem is simple: insert a sequence of d ...

  6. PAT 1145 Hashing - Average Search Time

    The task of this problem is simple: insert a sequence of distinct positive integers into a hash tabl ...

  7. 1145. Hashing - Average Search Time

      The task of this problem is simple: insert a sequence of distinct positive integers into a hash ta ...

  8. PAT_A1145#Hashing - Average Search Time

    Source: PAT A1145 Hashing - Average Search Time (25 分) Description: The task of this problem is simp ...

  9. PAT-1145(Hashing - Average Search Time)哈希表+二次探测解决冲突

    Hashing - Average Search Time PAT-1145 需要注意本题的table的容量设置 二次探测,只考虑正增量 这里计算平均查找长度的方法和书本中的不同 #include&l ...

随机推荐

  1. Bootstrap 侧边栏 导航栏

    http://blog.csdn.net/shangmingchao/article/details/49763351 实测效果图:

  2. Eclipse中jsp、js文件编辑时,卡死现象解决汇总(转)

    使用Eclipse编辑jsp.js文件时,经常出现卡死现象,在网上百度了N次,经过N次优化调整后,卡死现象逐步好转,具体那个方法起到作用,不太好讲.将所有用过的方法罗列如下:   1.取消验证 win ...

  3. Java的Regex --正则表达式

    一.概述 正则表达式通常被用来对字符串提供范围性的校验.替换那些符合某个模式(规则)的文本. 正则表达式所对应的类Pattern,所有的正则表达式都是在这个类下创建的.Pattern类用于创建一个正则 ...

  4. MongoDB Projection

    版权所有,未经许可,禁止转载 章节 MongoDB 入门 MongoDB 优势 MongoDB 安装 MongoDB 数据建模 MongoDB 创建数据库 MongoDB 删除数据库 MongoDB ...

  5. 使用Oracle VM VirtualBox安装CentOS 7.6操作系统

    使用Oracle VM VirtualBox安装CentOS 7.6操作系统                                                               ...

  6. P 1030 完美数列

    转跳点:

  7. Day1-T2

    原题目 在小X的认知里,质数是除了本身和1以外,没有其他因数的数. 但由于小 X对质数的热爱超乎寻常,所以小X同样喜欢那些虽然不是质数, 但却是由两个质数相乘得来的数. 于是,我们定义一个数小 X喜欢 ...

  8. content编码

    1.content有5种属性 a.content:“”                     //为空 b.content:attr(TItle)     //可以获取当前选中标签的属性值 eg: ...

  9. DispatcherServlet(2)_HandlerMapping

    HandlerMapping_xmind SpringMVC默认提供的HandlerMapping BeanNameUrlHandlerMapping SimpleUrlHandlerMapping ...

  10. 一天一个设计模式——Bridge桥接模式

    一.概念准备 在理解桥接模式之前,先要理解面向对象程序设计中的两个概念: 类的功能层次结构:假设现在有一个类Something,这个类有一些成员属性和成员方法,但是现有的功能不能满足要求,因此我们想扩 ...