博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PTA 数据结构与算法题目集(中文) 7-42 整型关键字的散列映射(25 分) 散列表+线性探测法
阅读量:3903 次
发布时间:2019-05-23

本文共 614 字,大约阅读时间需要 2 分钟。

给定一系列整型关键字和素数P,用除留余数法定义的散列函数将关键字映射到长度为P的散列表中。用线性探测法解决冲突。

输入格式:

输入第一行首先给出两个正整数N(≤1000)和P(≥N的最小素数),分别为待插入的关键字总数、以及散列表的长度。第二行给出N个整型关键字。数字间以空格分隔。

输出格式:

在一行内输出每个整型关键字在散列表中的位置。数字间以空格分隔,但行末尾不得有多余空格。

输入样例:

4 524 15 61 88

输出样例:

4 0 1 3

 散列表的应用加上线性探测法。。。

注意此题会有重复的元素输入,所以需要将某数的在散列表的位置记录下来。。

代码如下:

 

#include 
#include
#include
#include
using namespace std;const int maxn=1e6;int n,p;int vis[maxn]; //判断散列表某点是否已经有元素int is[maxn]; //判断某一数字是否放入散列表//初始化void init (){ memset (vis,0,sizeof(vis)); memset (is,-1,sizeof(is));}int main(){ scanf("%d%d",&n,&p); init(); for (int i=0;i

 

转载地址:http://npaen.baihongyu.com/

你可能感兴趣的文章
474. 一和零
查看>>
486. 预测赢家
查看>>
494. 目标和
查看>>
520. 检测大写字母
查看>>
数据处理和训练模型的技巧
查看>>
vb 中如何做同步 异步?
查看>>
geturl
查看>>
关于sizeof
查看>>
windows 核心编程笔记.070301
查看>>
WINDOWS核心编程笔记 070303
查看>>
终于解决了交叉表左上角,每页都显示的问题.
查看>>
windows核心编程 070309
查看>>
哈,又解决水晶报表的一个难题
查看>>
VC Ini文件处理
查看>>
一直误解sql事务的用法.
查看>>
转:利用C#实现分布式数据库查询
查看>>
转:Remoting系列(三)----对象的生命周期管理
查看>>
转:Remoting系列(二)----建立第一个入门程序
查看>>
转:Remoting系列(一)----Remoting的基本概念
查看>>
转:NET Remoting程序开发入门篇
查看>>