数据结构课程设计哈希表的设计与实现课程设计(数据结构哈希表查找姓名设计)

我负责小组里处理冲突。用RN【30】做随即数列。在冲突的时候使用作为随即增量。为防止重复,在赋值时做适当处理。这是处理前的代码:#include#include#include#include#include#includeusingnamespacestd;#defineMAX_NUM26typedefstructPreson//定义数

大家好,又见面了,我是你们的朋友全栈君。

数据结构课程设计哈希表的设计与实现课程设计(数据结构哈希表查找姓名设计)

数据结构课程设计哈希表的设计与实现课程设计(数据结构哈希表查找姓名设计)

我负责小组里处理冲突。

数据结构课程设计哈希表的设计与实现课程设计(数据结构哈希表查找姓名设计)

数据结构课程设计哈希表的设计与实现课程设计(数据结构哈希表查找姓名设计)

用RN【30】做随即数列。在冲突的时候使用作为随即增量。为防止重复,在赋值时做适当处理。

这是处理前的代码:

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include <conio.h>
#include<time.h>
using namespace std;

#define MAX_NUM 26

typedef struct Preson //定义数据结构 
{
	int num;
	char name[16];
	struct Preson *Link; 
}Student;

Student *Hashtab[MAX_NUM]; //定义哈希表 

int Hash(char str[])  //定义哈希函数 
{
	int val;
	char *p;
	p=str;
	while(*p!='\0')
	{
		val+=*p++;
	}
	return (val%MAX_NUM);
}

Student *cmp(Student *fir,Student *sec) // 判断两节点是否相同的函数 
{
	Student *pre; 
	pre=fir;
	while(pre!=NULL)
	{
		if(/*pre->num == sec->num || */!strcmp(pre->name,sec->name) /*允许重名存在*/)
		{
			return pre;
		}
		pre=pre->Link;
	}
	if(pre==NULL)
		return NULL;
}

void insert() //定义插入函数 
{
	Student *nodetemp;
	nodetemp = (Student *)malloc(sizeof(Student));
	nodetemp->Link=NULL;
	printf("请输入学生序号:");
	scanf("%d",&nodetemp->num);
	printf("请输入学生姓名:");
	scanf("%s",nodetemp->name);      //新节点建立完成 
	
	int index = Hash(nodetemp->name); 
	while(Hashtab[index]!=NULL)
	{
		if(strcmp((Hashtab[index]->name),nodetemp->name)==0)
		{
			printf("信息已存在\n");
			break;
		}
		else
		{   srand(time(NULL));
			index=(index+rand())%30;
		}
	}
	if(Hashtab[index]==NULL)
	{
	Hashtab[index] = nodetemp;
	printf("信息录入成功(imet)\n");
    }
	system("pause");
}

void find()
{
	Student *temp,*p;
	temp = (Student*)malloc(sizeof(Student));
	printf("请输入要查询同学的姓名:");
	scanf("%s",temp->name);
	int index = Hash(temp->name);
	p=cmp(Hashtab[index],temp);
	if(p==NULL)
		printf("记录不存在\n");
	else
	{
		printf("学号:%d,姓名:%s\n",p->num,p->name);
	}
	system("pause");
} 

void show()
{
	Student *p;
	printf("*******************************\n");
	printf("** 学号                 姓名 **\n");
	printf("*******************************\n");
	for(int i=0;i<MAX_NUM;i++)
	{
		if(Hashtab[i]!=NULL)
		{
			p=Hashtab[i];
			while(p!=NULL)
			{
				printf("** %-3d          %12s **\n",p->num,p->name);
				p=p->Link;
			}
		}
	}
	printf("*******************************\n");
	system("pause");
}

void menu()
{
	printf("************************************************\n");
	printf("**                                            **\n");
	printf("**          输入对应数字,实现对应操作        **\n");
	printf("**               1.  插入信息                 **\n");
	printf("**               2.  查找信息                 **\n");
	printf("**               3.  显示信息                 **\n");
	printf("**                                            **\n");
	printf("************************************************\n");
	int i;
	scanf("%d",&i);
	switch(i) 
	{
		case 1:
			insert();
			system("cls");
			menu();
			break; 
		case 2:
			find();
			system("cls");
			menu();
			break; 
		case 3:
			show();
			system("cls");
			menu();
			break; 
	}

} 
int main()
{
	for(int i=0;i<MAX_NUM;i++)//初始化哈希表
	{
		Hashtab[i]=NULL;
	} 
	int k=5;
	menu();
	return 0;
}

这是处理后的代码。

采用伪随机再散列处理冲突。

需要改动的地方有:

1、插入函数

2、查找函数

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include <conio.h>
#include<time.h>
using namespace std;

#define MAX_NUM 30

typedef struct Preson //定义数据结构 
{
	int num;
	char name[16];
	struct Preson *Link; 
}Student;

Student *Hashtab[MAX_NUM]; //定义哈希表 
int RN[30];//随即数列 


int Hash(char str[])  //定义哈希函数 
{
	int val;
	char *p;
	p=str;
	while(*p!='\0')
	{
		val+=*p++;
	}
	return (val%MAX_NUM);
}

Student *cmp(Student *fir,Student *sec) // 判断两节点是否相同的函数 
{
	Student *pre; 
	pre=fir;
	while(pre!=NULL)
	{
		if(/*pre->num == sec->num || */!strcmp(pre->name,sec->name) /*允许重名存在*/)
		{
			return pre;
		}
		pre=pre->Link;
	}
	if(pre==NULL)
		return NULL;
}

void insert() //定义插入函数 
{
	Student *nodetemp;
	nodetemp = (Student *)malloc(sizeof(Student));
	nodetemp->Link=NULL;
	printf("请输入学生序号:");
	scanf("%d",&nodetemp->num);
	printf("请输入学生姓名:");
	scanf("%s",nodetemp->name);      //新节点建立完成  
	int index = Hash(nodetemp->name); 
	while(Hashtab[index]!=NULL)
	{   int i=0;
		if(strcmp((Hashtab[index]->name),nodetemp->name)==0)//
		{
			printf("信息已存在\n");
			break;
		}
		else //若冲突
		{  
	  		index=RN[i];
		}
	}
	if(Hashtab[index]==NULL)
	{
	Hashtab[index] = nodetemp;
	printf("信息录入成功(imet)\n");
    }
	system("pause");
}

void find()
{   Student *temp,*p;
	temp = (Student*)malloc(sizeof(Student));
	printf("请输入要查询同学的姓名:");
	scanf("%s",temp->name);
	int index = Hash(temp->name);
	int i=0;
	while(strcmp(Hashtab[index]->name,temp->name)!=0&&Hashtab[index]!=NULL) //利用随机数列继续查找,直到找到或者链表为空。
	{
		index=RN[i];
		i++;
	}
	if(Hashtab[index]==NULL)
		printf("记录不存在\n");
	else if(strcmp(Hashtab[index]->name,temp->name)==0)
	{
		printf("学号:%d,姓名:%s\n",Hashtab[index]->num,Hashtab[index]->name);
	}
	system("pause");
} 

void show()
{
	Student *p;
	printf("*******************************\n");
	printf("** 学号                 姓名 **\n");
	printf("*******************************\n");
	for(int i=0;i<MAX_NUM;i++)
	{
		if(Hashtab[i]!=NULL)
		{
			p=Hashtab[i];
			while(p!=NULL)
			{
				printf("** %-3d          %12s **\n",p->num,p->name);
				p=p->Link;
			}
		}
	}
	printf("*******************************\n");
	system("pause");
}

void menu()
{
	printf("************************************************\n");
	printf("**                                            **\n");
	printf("**          输入对应数字,实现对应操作        **\n");
	printf("**               1.  插入信息                 **\n");
	printf("**               2.  查找信息                 **\n");
	printf("**               3.  显示信息                 **\n");
	printf("**                                            **\n");
	printf("************************************************\n");
	int i;
	scanf("%d",&i);
	switch(i) 
	{
		case 1:
			insert();
			system("cls");
			menu();
			break; 
		case 2:
			find();
			system("cls");
			menu();
			break; 
		case 3:
			show();
			system("cls");
			menu();
			break; 
	}

} 
int main()
{   
   srand((int)time(0));
 for(int i=0;i<30;i++)
 {
  RN[i]=rand()%30;
  for(int j=0;j<i;j++)//这里处理,防止随机数重复。
  {
   if(RN[i]==RN[j])
   {
    i--;
   }
  }
 }
	for(int i=0;i<MAX_NUM;i++)//初始化哈希表
	{
		Hashtab[i]=NULL;
	} 
	int k=5;
	menu();
	return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128366.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • yuicompressor java_YUI Compressor[通俗易懂]

    yuicompressor java_YUI Compressor[通俗易懂]简介根据雅虎卓越性能团队的说法,40%到60%的雅虎用户拥有空闲缓存体验,所有页面浏览量中约有20%是使用空缓存完成的(请参阅TenniTheurer在YUIBlog上的这篇文章)有关浏览器缓存使用的更多信息)。这一事实概述了保持网页尽可能轻量化的重要性。改进页面或Web应用程序的工程设计通常会带来最大的节省,而且应始终是主要策略。通过正确的设计,有许多提高性能的辅助策略,例如缩小代码,HTTP…

    2022年7月18日
    13
  • 互联网服务端测试之RPC接口测试「建议收藏」

    互联网服务端测试之RPC接口测试「建议收藏」开篇碎碎念:18年的时候写过一篇《互联网服务端测试是个啥(入门科普)》(指路https://blog.csdn.net/wangyueshu/article/details/81944250),主要面向的是那些没有接触过服务端测试,尤其是已有端上测试经验、而面对服务端测试时急需转换测试思维的那部分读者。3年过去了,转一圈再回来做服务端测试时,内容也有了扩展。原篇的接口更多的是指代HTTP接口,服务也更多的指代数据服务。而随着算法模型应用的逐渐深入,服务扩展到了模型、策…

    2022年10月13日
    3
  • 银行家算法c语言加注释,银行家算法C语言代码

    银行家算法c语言加注释,银行家算法C语言代码《银行家算法C语言代码》由会员分享,可在线阅读,更多相关《银行家算法C语言代码(10页珍藏版)》请在人人文库网上搜索。1、实验名称:银行家算法声明:杨秀龙学号:专业课:创新实验课111地图老师:霍林实验标题银行家算法实验的目的银行家算法如何避免死锁的更深层次理解设计思想银行家算法假定,根据进程的请求,在该进程的请求中已分配的资源上执行安全算法,如果可以满足其他进程的所有请求,则满足该进程的请求,否…

    2022年4月28日
    32
  • 【报错解决办法】ModuleNotFoundError: No module named ‘numba‘[通俗易懂]

    【报错解决办法】ModuleNotFoundError: No module named ‘numba‘[通俗易懂]numba是一款可以将python函数编译为机器代码的JIT编译器,经过numba编译的python代码(仅限数组运算),其运行速度可以接近C或FORTRAN语言。python之所以慢,是因为它是靠CPython编译的,numba的作用是给python换一种编译器。numba可以基于llvm动态生成优化代码,提高python的执行效率,只需要给python代码加上修饰器就好了。如果遇到ImportError:Nomodulenamednumba这样的问题,安装nu

    2025年8月14日
    2
  • IC验证培训——SystemVerilog通用程序库(下)

    IC验证培训——SystemVerilog通用程序库(下)路桑的个人网址:路科验证-IC验证培训-数字芯片验证五、类方法还是包函数?我们最初的直觉是将svlib作为一组SystemVerilog类呈现给用户。我们假设由一个类来表示一个正则表达式,另一个类来表示一个文件名,等等。从库写作者的角度来看,以这种方式打包用户数据是非常有吸引力的,因为它允许我们将任意隐藏数据与每个对象相关联。 我们在编写面向用户的API时,上遇到了一个严…

    2025年9月3日
    5
  • 【字幕制作】生肉资源的字幕问题解决经验分享 入门科普/一键机翻/在线识别/内嵌封装「建议收藏」

    【字幕制作】生肉资源的字幕问题解决经验分享 入门科普/一键机翻/在线识别/内嵌封装「建议收藏」当你不得不啃一个无内嵌字幕的生肉视频,而又急需中文翻译支持的时候?

    2022年7月27日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号