本篇文章為大家展示了C語(yǔ)言中怎么利用哈希表實(shí)現(xiàn)通訊錄,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

濱城網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)建站,濱城網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為濱城成百上千提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的濱城做網(wǎng)站的公司定做!
1.需求分析
本演示程序用C語(yǔ)言編寫(xiě),完成哈希表的生成,電話號(hào)碼的插入、以及查找等功能。
(1)按提示輸入相應(yīng)的聯(lián)系人的相關(guān)資料;
(2)以相應(yīng)的輸出形式輸出所存儲(chǔ)的的聯(lián)系人的資料;
(3)程序可以達(dá)到建立、添加、查找、打印的功能;
(4)程序可以判斷用戶輸入的非法數(shù)據(jù)并引導(dǎo)正確的輸入。
2.概要設(shè)計(jì)
存儲(chǔ)電話號(hào)碼的記錄時(shí),若在存儲(chǔ)位置和其關(guān)鍵字之間建立某種確定的對(duì)應(yīng)關(guān)系使得每個(gè)關(guān)鍵字和存儲(chǔ)結(jié)構(gòu)中一個(gè)唯一的存儲(chǔ)位置相對(duì)應(yīng),那么在進(jìn)行查找時(shí),根據(jù)這個(gè)對(duì)應(yīng)關(guān)系f就可以找到給定值K的像f(K)。若存儲(chǔ)結(jié)構(gòu)中存在關(guān)接找到所查記錄。這個(gè)對(duì)應(yīng)關(guān)系f稱為哈希(Hash)函數(shù)或散列函數(shù)。按照以上思路建立的表稱為哈希表或散列表。本案例設(shè)計(jì)主要考察散列表的建立、查找和修改。。
3.詳細(xì)設(shè)計(jì)
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct node
{
char num[11],name[15],address[20],city[15],etp[20];
struct node *next;
}NUM;
struct NUM *num_list[19];
int hash(char num[])
{
int i,k=0;
for(i=0;num[i]!='\0';i++)
{
k=10*k+num[i]-48; //字符轉(zhuǎn)化為數(shù)字
}
k=(k%19); //除余法求散列地址
return k;
}//c除留余數(shù)法處理電話號(hào)碼
void create()
{
struct node *p1;
int k1,m=0;
while(m==0)
{
printf("請(qǐng)輸入你想添加人的信息:num name address city etp,\n");
p1=(struct node *)malloc(sizeof(struct node));
scanf("%s",p1->num);
scanf("%s",p1->name);
scanf("%s",p1->address);
scanf("%s",p1->city);
scanf("%s",p1->etp);
k1=hash(p1->num);//用num數(shù)組值作為參數(shù)傳遞給哈希函數(shù)得到k1
p1->next=num_list[k1];//將k1得到的值作為數(shù)組的儲(chǔ)存地址賦值給頭結(jié)點(diǎn)的下一個(gè)節(jié)點(diǎn)
num_list[k1]=p1;//再將p1的數(shù)據(jù)傳遞給數(shù)組,故p1可以釋放作為下一個(gè)節(jié)點(diǎn)產(chǎn)生
printf("結(jié)束請(qǐng)按1,再次輸入請(qǐng)按0\n");
scanf("%d",&m);
}
printf("通訊表已經(jīng)創(chuàng)建\n");
}
void dlter()
{
char num[11];
int k1;
int find=0;
struct node *f;
printf("請(qǐng)查詢要修改的聯(lián)系人的電話:\n:");
scanf("%s",num);
k1=hash(num);
f=num_list[k1];
while(f!=NULL)
{
if(strcmp(f->num,num)==0)
{
printf("查找到了!請(qǐng)輸入要修改的人的資料:\n");
scanf("%s%s%s",f->num,f->name,f->address,f->city,f->etp);
find=1;
}
f=f->next;
}
if(find=0)
printf("沒(méi)有找到要?jiǎng)h除的節(jié)點(diǎn)!");
}
void list()
{
struct node *f;//打印節(jié)點(diǎn)指針
int i;
printf("打印通訊錄如下:\n");
for(i=0;i<19;i++)
{
f=num_list[i];
while(f!=NULL)
{
printf("--->num:%s\t name:%s\t address:%s\t city:%s\t etp:%s\t \n",f->num,f->name,f->address,f->city,f->etp);
f=f->next;
}
}
}
void add()
{
char num[11],name[15],address[20],city[15],etp[20];
struct node *p1;
int k1;
printf("請(qǐng)輸入新添加的人的信息:電話 姓名 地址 城市 郵箱\n");
p1=(struct node *)malloc(sizeof(struct node));
scanf("%s%s%s",num,name,address);
strcpy(p1->num,num);
strcpy(p1->name,name);
strcpy(p1->address,address);
strcpy(p1->city,city);
strcpy(p1->etp,etp);
k1=hash(p1->num);
p1->next=num_list[k1];
num_list[k1]=p1;
printf("ok\n");
}
void search()
{
char num[11];
int k1;
int find=0;
struct node *f;
printf("請(qǐng)輸入查詢?nèi)说碾娫捥?hào)碼:");
scanf("%s",num);
k1=hash(num);
f=num_list[k1];
while(f!=NULL)
{
if(strcmp(f->num,num)==0)
{
printf("所要查找的聯(lián)系人信息 :num:%s name:%s address:%s city:%s etp:%s\n",f->num,f->name,f->address,f->city,f->etp);
find=1;
}
f=f->next;
}
if(find=0)
printf("此聯(lián)系人沒(méi)有找到!");
}
void main()
{
int i;
char x;
for(i=0;i<19;i++)
{
num_list[i]=NULL;
}
while(1)
{
// system("cls");
printf("\n");
printf("★★★★★★★★★通訊錄★★★★★★★★★\n");
printf("★◆----------------------------------◆★\n");
printf("★| 1.建立 |★\n");
printf("★| |★\n");
printf("★| 2.查找 |★\n");
printf("★| |★\n");
printf("★| 3.添加 |★\n");
printf("★| |★\n");
printf("★| 4.修改 |★\n");
printf("★| |★\n");
printf("★| 5.打印 |★\n");
printf("★| |★\n");
printf("★| 6.結(jié)束 |★\n");
printf("★◆----------------------------------◆★\n");
printf("★★★★★★★★★★★★★★★★★★★★★\n");
// x=getchar();
scanf("%s",&x);
switch(x)
{
case '1': create();break;
case '2': search();break;
case '3': add();break;
case '4': dlter();break;
case '5': list();break;
case '6': return;
default:printf("請(qǐng)重新輸入;\n");
}
}
}上述內(nèi)容就是C語(yǔ)言中怎么利用哈希表實(shí)現(xiàn)通訊錄,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)站名稱:C語(yǔ)言中怎么利用哈希表實(shí)現(xiàn)通訊錄
鏈接URL:http://www.chinadenli.net/article8/piseop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、搜索引擎優(yōu)化、網(wǎng)站維護(hù)、面包屑導(dǎo)航、Google、網(wǎng)站營(yíng)銷
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)