数据结构,哈希表hash设计实验
- 数据结构实验,hash表
- 采用链地址法处理hash冲突
- 代码全部自己写,转载请留本文连接,
- 附上代码
#include<stdlib.h>
#include<stdio.h>
#include<string.h>
#include<conio.h> #define NAMESIZE 20//姓名长度
#define NULLKEY -32768//hash表空值
#define HASHSIZE 30//定义hash表长度 typedef struct student
{
char name[NAMESIZE];
int Snum;
int Tnum;
student *next=NULL;
}stu; typedef struct
{
stu ** list;
int count;
}HashTable; int InitHashtable(HashTable *hash)
{
hash->count=0;
hash->list=(stu **)malloc(HASHSIZE *sizeof(stu *));
if(!hash->list)
return -1;
for(int i=0;i<HASHSIZE;i++)
{
hash->list[i]=NULL;
}
return 1;
}
int hash(stu stu)
{
int hashseed=0;
for(int a=0;stu.name[a]!='\0';a++)
{
hashseed=hashseed*7+(int)stu.name[a];
}
int hashvalue=NULLKEY;
srand(hashseed);
hashvalue=rand()%HASHSIZE;
return hashvalue;
}
int intohashtable(HashTable *htable,student *stu)
{
int H1=hash(*stu);
if(htable->list[H1]!=NULL)//hash冲突
{
student *p;
p=(student *)malloc(sizeof(student));
p=stu;
p->next=htable->list[H1];
htable->list[H1]=p; }
else
htable->list[H1]=stu;
htable->count++;
return 1;
}
int addstudent(HashTable *htable)
{
char name[NAMESIZE];
int snum,tnum;
stu *stu1;
stu1=(student *)malloc(sizeof(student));
printf("请输入姓名:\t");fflush(stdin);
scanf("%s",name);
printf("请输入学号:\t");
scanf("%d",&snum);
printf("请输入电话号:\t");
scanf("%d",&tnum);
if(!name)
{
printf("addstudent__error");
return 0;
}
strcpy(stu1->name,name);
stu1->Snum=snum;
stu1->Tnum=tnum;
stu1->next=NULL;
if(intohashtable(htable,stu1))
return 1;
else
{
printf("into_error");
return 0;
}
}
int findhashtable(HashTable *htable)
{
printf("\t2-查找\n");
char name[NAMESIZE];
printf("请输入要查找的姓名:");
scanf("%s",name);
stu stu0;
strcpy(stu0.name,name);
stu0.next=NULL;
stu0.Snum=0;
stu0.Tnum=0;
int hashkey;
hashkey=hash(stu0);
if(htable->list[hashkey]==NULL)
printf("查找的值不存在\n");
if(htable->list[hashkey!=NULL])
{
stu *p;
p=htable->list[hashkey];
while(p)
{
if(name==p->name)
printf("你找的信息为:\n姓名:%s\t学号:%d\t电话号码%d\n",htable->list[hashkey]->name,htable->list[hashkey]->Snum,htable->list[hashkey]->Tnum);
if(p->next==NULL)
break;
p=p->next;
}
}
printf("你找的信息为:\n姓名:%s\t学号:%d\t电话号码%d\n",htable->list[hashkey]->name,htable->list[hashkey]->Snum,htable->list[hashkey]->Tnum);
getch();
}
int main()
{
HashTable *htable;
htable =(HashTable *)malloc(sizeof(HashTable));
InitHashtable(htable);
int T=1;
for(int a=1;T;a++)
{
system("cls");
printf("\t哈希表设计实验\n");
printf("1-添加\n2-查找\n3-输出hash表\n0-退出\n");
scanf("%d",&T);
if(T==1)
for(char c;1;1)
{
if(!addstudent(htable))
printf("addstudent返回error\n");
printf("是否继续输入如 y/n:\t");
fflush(stdin);
c=getchar();
if(c=='n'||c=='N')
break;
}
if(T==2)
findhashtable(htable);
if(T==3)
{
student *p;
printf("储存的数据个数为%d个\n",htable->count);
for(int a=0;a<HASHSIZE;a++)
{
printf("%d\t",a);
p=htable->list[a];
int t=0;
while(p)
{
t=1;
printf("%s\t",p->name);
// if(p->next==NULL)
// break;
p=p->next;
}
if(t==0)
printf("0");
printf("\n");
}
getch();
}
}
}
数据结构,哈希表hash设计实验的更多相关文章
- Redis原理再学习04:数据结构-哈希表hash表(dict字典)
哈希函数简介 哈希函数(hash function),又叫散列函数,哈希算法.散列函数把数据"压缩"成摘要,有的也叫"指纹",它使数据量变小且数据格式大小也固定 ...
- 数据结构 哈希表(Hash Table)_哈希概述
哈希表支持一种最有效的检索方法:散列. 从根来上说,一个哈希表包含一个数组,通过特殊的索引值(键)来访问数组中的元素. 哈希表的主要思想是通过一个哈希函数,在所有可能的键与槽位之间建立一张映射表.哈希 ...
- 算法与数据结构基础 - 哈希表(Hash Table)
Hash Table基础 哈希表(Hash Table)是常用的数据结构,其运用哈希函数(hash function)实现映射,内部使用开放定址.拉链法等方式解决哈希冲突,使得读写时间复杂度平均为O( ...
- (js描述的)数据结构[哈希表1.1](8)
(js描述的)数据结构[哈希表1.1](8) 一.数组的缺点 1.数组进行插入操作时,效率比较低. 2.数组基于索引去查找的操作效率非常高,基于内容去查找效率很低. 3.数组进行删除操作,效率也不高. ...
- 数据结构 -- 哈希表(hash table)
简介 哈希表(Hash table,也叫散列表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度.这个映射函 ...
- C#数据结构----------------------------哈希表源码解析
转载: C# Hashtable源码剖析 源代码版本为 .NET Framework 4.6.1 本系列持续更新,敬请关注 有投入,有产出. Hashtable实现一个哈希表(也叫散列表),将键映射到 ...
- PHP关联数组和哈希表(hash table) 未指定
PHP有数据的一个非常重要的一类,就是关联数组.又称为哈希表(hash table),是一种很好用的数据结构. 在程序中.我们可能会遇到须要消重的问题,举一个最简单的模型: 有一份username列表 ...
- JAVA数据结构--哈希表的实现(分离链接法)
哈希表(散列)的定义 散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度 ...
- 第三十四篇 玩转数据结构——哈希表(HashTable)
1.. 整型哈希函数的设计 小范围正整数直接使用 小范围负整数整体进行偏移 大整数,通常做法是"模一个素数" 2.. 浮点型哈希函数的设计 转成整型进行处理 3.. 字符串 ...
随机推荐
- Java中List,Set,Map区别
在Java开发面试中,面试官最常问到的就是Java集合,免不了要让面试者说出之间的区别,下面博主就对其做了总结. 1.集合与数组的区别 长度区别:数组是固定长度,集合长度可变: 内容区别:数组可以是基 ...
- 04、MyBatis DynamicSQL(Mybatis动态SQL)
1.动态SQL简介 动态 SQL是MyBatis强大特性之一. 动态 SQL 元素和使用 JSTL 或其他类似基于 XML 的文本处理器相似. MyBatis 采用功能强大的基于 OGNL 的表达式来 ...
- MySQL获取webshell的几种方式
select ... into outfile 需要满足的条件 对web目录有写权限 GPC关闭(GPC:是否对单引号转义) 有绝对路径(读文件可以不用,写文件需要) 没有配置secure-file- ...
- laravel 验证器使用
1.前后端不分离 (form表单提交) 控制器定义验证规则 <?php namespace App\Http\Controllers\Admin; use Illuminate\Http\Req ...
- Springboot 框架整理,建议做开发的都看看,整理的比较详细!
什么是 Spring Boot? SpringBoot是Spring项目中的一个子工程,与我们所熟知的Spring-framework 同属于spring的产品,是用来简化 spring 初始搭建和开 ...
- 在 Spark 数据导入中的一些实践细节
本文由合合信息大数据团队柳佳浩撰写 1.前言 图谱业务随着时间的推移愈发的复杂化,逐渐体现出了性能上的瓶颈:单机不足以支持更大的图谱.然而,从性能上来看,Neo4j 的原生图存储有着不可替代的性能优势 ...
- vim进入粘贴模式
最近使用linux的vim编辑器编写程序时,遇到一些繁琐的模板想要复制粘贴进去,直接进入插入模式点复制,复制出来的格式不对没办法运行 解决办法: 这是因为 Vim 自动缩进了,按照如下设置可以解决该问 ...
- Python_生成器和迭代器的区别
迭代器和生成器的区别是什么?这个问题面试的时候经常作为灵魂拷问.今天一起从概念到代码梳理一遍,作为总结和记录. 区别是: 生成器的好处是延迟计算,一次返回一个结果.也就是说,它不会一次生成所有的结果, ...
- Java数据结构(十)—— 树
树 树的概念和常用术语 常用术语 节点 根节点 父节点 子节点 叶子节点:没有子节点的节点 节点的权:节点的值 路径:节点A到节点B的路径 层 子树 树的高度:最大层数 森林:多颗子树构成森林 二叉树 ...
- 三. Vue组件化
1. 认识组件化 1.1 什么是组件化 人面对复杂问题的处理方式 任何一个人处理信息的逻辑能力都是有限的,所以当面对一个非常复杂的问题时我们不太可能一次性搞定一大堆的内容. 但是我们人有一种天生的能力 ...