第十五周 用哈希法组织关键字
2015-12-18 08:30
260 查看
问题及代码:
/*
* 烟台大学计算机与控制工程学院
*文件名称:mian.cpp
*作 者:刘磊
*完成日期:2015年12月18日
*版 本 号:v1.0
*
*问题描述:基数排序
*
*输入描述:无
*程序输出:无
*/
#include <stdio.h>
#include <string.h>
#define N 15
#define M 26
int H(char *s)
{
return ((*s-'a'+1)%M);
}
int main()
{
char *s
= {"if", "while", "for", "case", "do", "break", "else", "struct", "union", "int", "double", "float", "char", "long", "bool"};
int i, j, k;
char HT[M][10];
int Det[M]; //存放探测次数
for(i=0; i<M; i++)
{
HT[i][0]='\0';
Det[i]=0;
}
printf("字符串 key\tH(key)\n");
printf("------------------------\n");
for(i=0; i<N; i++)
{
j=H(s[i]); //求哈希值
printf("%s\t\t%d\n", s[i],j);
k=0; //探测次数初值
while(1)
{
k++; //累加探测次数
if(HT[j][0]=='\0') //当不冲突时,直接放到该处
{
strcpy(HT[j], s[i]);
break;
}
else //冲突时,采用线性探查法求下一个地址
{
j=(j+1)%M;
}
}
Det[j]=k;
}
printf("---------------------\n");
printf("哈希表\n");
printf("位置\t字符串\t探查次数\n");
printf("---------------------\n");
for(i=0; i<M; i++)
printf("%d\t%s\t%d\n", i, HT[i], Det[i]);
printf("---------------------\n");
k=0;
for(i=0; i<M; i++)
k+=Det[i];
printf("查找成功情况下的平均查找长度 %f\n", 1.0*k/N);
return 0;
}
运行结果:
/*
* 烟台大学计算机与控制工程学院
*文件名称:mian.cpp
*作 者:刘磊
*完成日期:2015年12月18日
*版 本 号:v1.0
*
*问题描述:基数排序
*
*输入描述:无
*程序输出:无
*/
#include <stdio.h>
#include <string.h>
#define N 15
#define M 26
int H(char *s)
{
return ((*s-'a'+1)%M);
}
int main()
{
char *s
= {"if", "while", "for", "case", "do", "break", "else", "struct", "union", "int", "double", "float", "char", "long", "bool"};
int i, j, k;
char HT[M][10];
int Det[M]; //存放探测次数
for(i=0; i<M; i++)
{
HT[i][0]='\0';
Det[i]=0;
}
printf("字符串 key\tH(key)\n");
printf("------------------------\n");
for(i=0; i<N; i++)
{
j=H(s[i]); //求哈希值
printf("%s\t\t%d\n", s[i],j);
k=0; //探测次数初值
while(1)
{
k++; //累加探测次数
if(HT[j][0]=='\0') //当不冲突时,直接放到该处
{
strcpy(HT[j], s[i]);
break;
}
else //冲突时,采用线性探查法求下一个地址
{
j=(j+1)%M;
}
}
Det[j]=k;
}
printf("---------------------\n");
printf("哈希表\n");
printf("位置\t字符串\t探查次数\n");
printf("---------------------\n");
for(i=0; i<M; i++)
printf("%d\t%s\t%d\n", i, HT[i], Det[i]);
printf("---------------------\n");
k=0;
for(i=0; i<M; i++)
k+=Det[i];
printf("查找成功情况下的平均查找长度 %f\n", 1.0*k/N);
return 0;
}
运行结果:
相关文章推荐
- 第十六周--期末总结
- ZZUOJ-10434: good string
- 2015-12-18 第十六周 排序(2)
- 第十五周 哈希表及其运算的实现
- 第16周项目插入排序之希尔排序
- 第十周 项目三 利用二叉树遍历思想解决问题(2)
- 第16周项目4——英文单词的基数排序
- 验证算法(3)冒泡排序
- 第15周项目3 - B-树的基本操作
- 第九周实践项目二--对称矩阵压缩存储的实践和应用
- 第十六周上机实践—项目2—大数据集上排序算法性能的体验
- jQuery复选框全选反选操作
- 2015-12-18 第十六周 排序
- 第十六周项目1-验证算法(1)-直接插入排序
- URLConnection 和 HttpClients 发送请求范例
- 第十六周 学期总结
- C++(简单工厂)
- 第十周 项目三 利用二叉树遍历思想解决问题(1)
- 第十二周项目二----操作用邻接表存储的图
- 数据结构学习心得