亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hash.cpp

?? 實現哈希表的創建、查找、插入
?? CPP
字號:
#include <stdio.h>
#include <malloc.h>
#include <process.h>
#include <iostream.h>
 
#define NULL_KEY 0
#define OVERFLOW -3
#define SUCCESS 1
#define UNSUCCESS 0
#define DUPLICATE -1
#define OK 1
#define ERROR 0
#define N 10

#define EQ(a,b) ((a)==(b))
#define LT(a,b) ((a)<(b))
#define LQ(a,b) ((a)<=(b))

typedef int Status;


int hashsize[]={11,19,29,37};
int m;

typedef struct 
{
	int *elem;
	int count;
	int sizeindex;
}HashTable;

void InitHashTable(HashTable *H)
{
	H->count=0;
	H->sizeindex=0;
	m=hashsize[0];
	H->elem=(int *)malloc(m*sizeof(int));
	if(!H->elem)
		exit(OVERFLOW); 
	for(int i=0;i<m;i++)
		H->elem[i]=NULL_KEY; 
}

/*void DestroyHashTable(HashTable *H)
{

	free(H->elem);//?????
	H->elem=NULL;
	H->count=0;
	H->sizeindex=0;
} */

int Hash(int k)
{
	return k%m;
}

void collision(int &p,int collision)
{
	p=(p+collision)%m;
} 


Status SearchHash(HashTable *H,int key,int &p,int &c)
{
	p=Hash(key);
	int q=p;
	while(H->elem[p]!=NULL_KEY && !EQ(key,H->elem[p]))
	{
		p=q;
		c++;
		collision(p,c);
	}
	if EQ(key,H->elem[p])
		return SUCCESS;
	else
		return UNSUCCESS;

}

void TraverseHash(HashTable *H)
{
	for(int i=0;i<m;i++)
		if(H->elem[i]!=NULL_KEY)
			cout<<"adress"<<"("<<i<<")"<<"="<<H->elem[i]<<endl;

}

//void RecreateHashTable();

Status InsertHash(HashTable *H,int k)
{
	int p;
	int c=0;
	if(SearchHash(H,k,p,c))
		return DUPLICATE;
	else if(c<hashsize[(*H).sizeindex]/2) 
	{ 
		(*H).elem[p]=k;
		++(*H).count;
		return OK;
	}
	else
		//RecreateHashTable(H); 
	return ERROR;
}

void RecreateHashTable(HashTable *H)
{
	int i,num;
	num=H->count;			//num為原哈希表中的記錄數目
	int *p=(int*)malloc(num*sizeof(int));
	int *t=p;
	printf("重建哈希表\n");
	for(i=0;i<m;i++)		//保存原有的數據到p中 
		if((H->elem[i])!=NULL_KEY) // 該單元有數據 
		{
			*p=H->elem[i];
			p++;
		}
		H->count=0;
		H->sizeindex++;			//增大存儲容量 
		m=hashsize[H->sizeindex];
		int *elem=(int*)malloc(m*sizeof(int));
		if(!elem)
			exit(OVERFLOW);		//存儲分配失敗
		for(i=0;i<m;i++)
			H->elem[i]=NULL_KEY; //未填記錄的標志(初始化)
		for(i=0;i<num;i++)		//將原有的數據按照新的表長插入到重建的哈希表中
		{
			InsertHash(H,*t);
			t++;
		}
}  

Status Find(HashTable *H,int key,int &p)
{
	int c=0;
	p=Hash(key);
	int q=p;
	while(H->elem[p]!=NULL_KEY && !EQ(key,H->elem[p]))
	{
		c++;
		p=q;
		collision(p,c);
	}
	if EQ(key,H->elem[p])
		return SUCCESS;
	else
		return UNSUCCESS;
}
int main()
{
	int r[N]={17,60,29,38,60,2,3,4,1,13};//查找表
	HashTable h;
	int i,p;
	Status j;
	int k;
	InitHashTable(&h);
	for(i=0;i<N;i++)  //插入前N-1個記錄
	{ 
		j=InsertHash(&h,r[i]);
		if(j==DUPLICATE)
			cout<<"表中已有關鍵字為"<<r[i]<<"的記錄,無法再插入記錄"<<r[i]<<endl;
		if(j==OK)
			cout<<r[i]<<"插入成功!"<<endl;
		if(j==ERROR)
		{
			cout<<r[i]<<"在插入過程中,沖突次數過大,所以重建哈希表"<<endl;
			RecreateHashTable(&h);
			j=InsertHash(&h,r[i]);
		}
	}
	cout<<"按哈希地址的順序遍歷哈希表:"<<endl;
	TraverseHash(&h);
	
	cout<<"請輸入待查找記錄的關鍵字: "<<endl;
	//while(getchar()!='a')
	//{
		cin>>k;
		j=Find(&h,k,p); //查找
		if(j==SUCCESS)
			cout<<"adress"<<p<<"is"<<h.elem[p]<<endl;
		//print(p,h.elem[p]);
		else
			cout<<"沒找到"<<endl;
	//}

	cout<<"要插入的關鍵字"<<endl;
	cin>>k;
	j=InsertHash(&h,k); //插入記錄 
	if(j==ERROR) // 重建哈希表 
	{
		RecreateHashTable(&h);
		j=InsertHash(&h,k); // 重建哈希表后重新插入記錄
		cout<<"按哈希地址的順序遍歷重建后的哈希表:"<<endl;
		TraverseHash(&h);
	}
	if(j==DUPLICATE)
		cout<<"表中已有關鍵字為<<r[i]<<的記錄,無法再插入記錄r[i]"<<endl;
	if(j==OK)
		cout<<"插入成功!"<<endl;
	TraverseHash(&h);
	//cout<<h.elem[1];
//	DestroyHashTable(&h);

	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本精品一级二级| 美女网站色91| 色综合久久六月婷婷中文字幕| 国产亚洲一二三区| 成人免费高清在线观看| 国产精品日韩成人| 色婷婷综合久色| 亚洲小说欧美激情另类| 欧美在线观看视频一区二区 | 日本一区中文字幕| 欧美一区二区三区免费观看视频 | 亚洲大尺度视频在线观看| 欧美日韩精品一区视频| 日韩高清在线一区| 精品国产乱码久久| av电影在线观看不卡| 亚洲综合清纯丝袜自拍| 日韩视频在线观看一区二区| 国产精品99久| 亚洲精品乱码久久久久久久久| 欧美日韩三级视频| 国产精品自在在线| 亚洲欧美国产77777| 欧美三级三级三级| 国产酒店精品激情| 亚洲一二三四在线观看| 精品999在线播放| 91视频一区二区三区| 免费人成精品欧美精品| 国产精品白丝在线| 91精品国产美女浴室洗澡无遮挡| 懂色av中文一区二区三区| 亚洲综合丝袜美腿| 久久免费电影网| 欧美性猛片xxxx免费看久爱 | 国产成人丝袜美腿| 亚洲成人精品一区| 亚洲超碰97人人做人人爱| 欧美一区二区三区播放老司机| 国产很黄免费观看久久| 日韩和的一区二区| 国产精品午夜久久| 日韩欧美中文字幕精品| 一本大道久久a久久综合| 国产精品影视在线| 亚洲成人一区在线| 中文字幕亚洲区| 久久综合色婷婷| 欧美欧美欧美欧美首页| 色综合久久88色综合天天免费| 国产九九视频一区二区三区| 免费在线观看成人| 亚洲成人自拍偷拍| 亚洲三级在线看| 亚洲国产高清aⅴ视频| 精品国产91洋老外米糕| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲成人av资源| 亚洲国产精品av| 精品国产网站在线观看| 91精品欧美一区二区三区综合在 | 国产一区二区h| 久久综合国产精品| 欧美精品乱码久久久久久| 97精品超碰一区二区三区| 国产一区二区日韩精品| 日韩精品一二三区| 午夜精品久久久久久久| 亚洲影院久久精品| 一区二区三区在线观看欧美| 中文字幕一区二区三区不卡| 国产欧美日韩在线观看| 久久久久久久久久久久久夜| 欧美va天堂va视频va在线| 欧美精品久久99久久在免费线 | 91色综合久久久久婷婷| 成人教育av在线| 成人99免费视频| 菠萝蜜视频在线观看一区| 白白色 亚洲乱淫| jlzzjlzz亚洲日本少妇| 在线不卡中文字幕播放| 欧美日韩一区小说| 51精品秘密在线观看| 日韩午夜精品视频| 精品国产免费视频| 日本一区二区三区dvd视频在线| 国产网站一区二区三区| 国产精品久久久久久久久久免费看| 国产欧美一区在线| 日韩伦理电影网| 亚洲一区二区在线播放相泽| 性欧美疯狂xxxxbbbb| 日本aⅴ免费视频一区二区三区| 美腿丝袜亚洲三区| 国产精品99久久久久久久vr| aaa亚洲精品| 欧洲另类一二三四区| 欧美日韩免费一区二区三区视频| 91精品国产综合久久久久久久久久| 日韩欧美视频在线| 国产日韩影视精品| 亚洲精品视频观看| 日本美女一区二区三区| 国产精品香蕉一区二区三区| 高清av一区二区| 一本到高清视频免费精品| 在线综合亚洲欧美在线视频| 精品国产麻豆免费人成网站| 综合久久久久久| 日韩国产精品91| 福利电影一区二区三区| 欧美三级蜜桃2在线观看| 日韩欧美专区在线| 中文字幕精品—区二区四季| 亚洲成人免费观看| 国产精品一卡二| 一本色道久久综合狠狠躁的推荐| 日韩一区二区视频| 亚洲欧洲av在线| 蜜臀av性久久久久蜜臀aⅴ| 不卡av在线免费观看| 91精品国产乱码| 日韩一区中文字幕| 久久国产精品免费| 在线免费av一区| 欧美精品一区二区久久久| 亚洲主播在线观看| 国产福利电影一区二区三区| 欧美日韩国产综合一区二区三区| 国产丝袜美腿一区二区三区| 亚洲国产精品尤物yw在线观看| 国产美女娇喘av呻吟久久| 在线亚洲高清视频| 中文字幕精品一区二区三区精品| 日韩福利视频导航| 91麻豆swag| 国产午夜久久久久| 青娱乐精品视频| 日本韩国一区二区三区视频| 久久免费精品国产久精品久久久久 | 国产精品久久久久婷婷| 另类小说图片综合网| 日韩欧美国产成人一区二区| 一区二区三区久久| 成人三级伦理片| 久久五月婷婷丁香社区| 午夜视频在线观看一区二区| 99久久国产综合精品麻豆| 久久综合国产精品| 久久国产精品99久久人人澡| 欧美欧美午夜aⅴ在线观看| 亚洲精品欧美专区| 波多野结衣精品在线| 久久久激情视频| 激情av综合网| 日韩免费高清av| 日本美女视频一区二区| 欧美欧美午夜aⅴ在线观看| 亚洲一区二区美女| 色狠狠av一区二区三区| 亚洲色图20p| 91麻豆国产自产在线观看| 亚洲三级小视频| 91在线观看成人| 亚洲免费在线视频一区 二区| 成人免费毛片嘿嘿连载视频| 欧美国产一区二区在线观看| 国产99精品国产| 欧美—级在线免费片| 福利一区二区在线| 国产精品久久久久永久免费观看| 国产成人自拍网| 国产欧美精品一区二区色综合朱莉 | 97se亚洲国产综合自在线不卡| 国产精品色在线观看| 高清在线观看日韩| 国产女主播一区| 99久久精品一区二区| 樱花草国产18久久久久| 欧美私模裸体表演在线观看| 舔着乳尖日韩一区| 日韩一区二区三| 国产一区二三区好的| 国产欧美日韩激情| 91美女片黄在线| 亚洲国产wwwccc36天堂| 欧美一级专区免费大片| 美国十次综合导航| 久久嫩草精品久久久精品一| 不卡av在线网| 亚洲国产精品欧美一二99| 91精品国产91久久久久久最新毛片 | 精品一区二区三区久久| 久久精品日产第一区二区三区高清版| 成人性生交大合| 亚洲高清视频在线| 精品日韩一区二区三区| 成人精品国产一区二区4080| 一个色在线综合|