91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言數據結構哈希表是什么

發布時間:2022-02-28 09:16:55 來源:億速云 閱讀:173 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關C語言數據結構哈希表是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

C語言數據結構哈希表是什么

C語言數據結構哈希表是什么

C語言數據結構哈希表是什么

C語言數據結構哈希表是什么

C語言數據結構哈希表是什么

C語言數據結構哈希表是什么

C語言數據結構哈希表是什么

/*
 * 程序名:hash.c,此程序演示哈希表的實現,數據元素單鏈表帶頭結點。
 * 
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
// 哈希表中數據元素的結構體。
typedef struct Element
{
  unsigned int key; // 關鍵字。
  int value;        // 數據元素其它數據項,可以是任意數據類型。
  // char value[1001];        // 數據元素其它數據項,可以是任意數據類型。
}Element;
 
// 數據元素單鏈表。
typedef struct Node
{
  Element elem;      // 數據元素。
  struct Node *next; // next指針。
}Node;
 
// 哈希表
typedef struct HashTable
{
  struct Node *head;  // 數據元素存儲基址,動態分配數組。
  int tablesize;      // 哈希表當前大小,即表長。
  int count;          // 哈希表中數據元素的個數。
}HashTable;
 
// 初始化哈希表,tablesize為哈希表的表長,返回哈希表的地址。
HashTable *InitHashTable(const unsigned int tablesize)
{
  // 分配哈希表。
  HashTable *hh=(HashTable *)malloc(sizeof(HashTable));
 
  hh->tablesize=tablesize;  // 哈希表長。
 
  // 分配和初始化數據元素單鏈表的頭結點。
  hh->head=(Node *)malloc((hh->tablesize)*sizeof(Node));
  memset(hh->head,0,(hh->tablesize)*sizeof(Node));
 
  hh->count=0;  // 哈希表中數據元素個數置為0。
 
  return hh;
}
 
// 哈希函數。
unsigned int Hash(HashTable *hh,unsigned int key)
{
  return key%hh->tablesize;  // 對表長取余。
}
 
// 在哈希表中查找關鍵字,成功返回單鏈表結點的地址,失敗返回空。
Node *LookUp(HashTable *hh,unsigned int key)
{
  int ii;
 
  ii=Hash(hh,key);  // 獲取關鍵key的哈希地址。
 
  Node *pp=hh->head[ii].next;
 
  // 遍歷單鏈表。
  while( (pp!=NULL) && (pp->elem.key!=key) )
  {
    pp=pp->next;
  }
 
  return pp;
}
 
// 從哈希表中刪除關鍵及其數據,成功返回1,如果關鍵字不存在返回0。
int Delete(HashTable *hh,unsigned int key)
{
  int ii;
 
  ii=Hash(hh,key);  // 獲取關鍵key的哈希地址。
 
  Node *pp=&hh->head[ii];
 
  // 遍歷單鏈表,pp指針停留在待刪除關鍵key的前一結點。
  while( (pp->next!=NULL) && (pp->next->elem.key!=key) )
  {
    pp=pp->next;
  }
 
  if (pp->next==NULL) return 0;  // 查找失敗。
 
  Node *tmp=pp->next;        // tmp為將要刪除的結點。
  pp->next=pp->next->next;   // 寫成p->next=tmp->next更簡潔。
 
  free(tmp);     // 釋放結點。
 
  hh->count--;   // 表中元素個數減1。
 
  return 1;
}
 
// 向哈希表中插入數據元素,成功返回1,如果數據元素關鍵字已存在,返回0。
int Insert(HashTable *hh,Element *ee)
{
  // 查找關鍵字是否已存在,如果存在,插入失敗。
  Node *pp=LookUp(hh,ee->key);
 
  if (pp!=NULL) { printf("關鍵字%d已存在。\n",ee->key); return 0; }
  
  Node *qq=(Node *)malloc(sizeof(Node));
 
  memcpy(&qq->elem,ee,sizeof(Element));
 
  // 用頭插法插入新數據元素。
  int ii=Hash(hh,ee->key);
  qq->next=hh->head[ii].next;
  hh->head[ii].next=qq;
  
  hh->count++;   // 表中元素個數加1。
 
  return 1;
}
 
// 銷毀哈希表
void FreeHashTable(HashTable *hh)
{
  int ii;
 
  Node *pp,*qq;
 
  // 釋放全部的單鏈表。
  for(ii=0;ii<hh->tablesize;ii++)
  {
    pp=hh->head[ii].next;
    while(pp)
    {
      qq=pp->next;
      free(pp);
      pp=qq;
    }
  }
 
  // 釋放全部單鏈表的頭結點數組。
  free(hh->head);
 
  free(hh);  // 釋放哈希表。
}
 
// 打印哈希表。
void PrintTable(HashTable *hh)
{
  int ii; 
 
  for (ii=0;ii<hh->tablesize;ii++)
  {
    Node *pp=hh->head[ii].next;
    while (pp)
    {
      printf("[%d-%d] ",pp->elem.key,pp->elem.value);
      // printf("[%d-%s] ",pp->elem.key,pp->elem.value);
      pp=pp->next;
    }
 
    printf("^\n");
  }
 
  printf("\n");
}
 
int main()
{
  // 初始化哈希表。
  HashTable *hh=InitHashTable(10);
 
  Element ee;
 
  // 插入數據元素,關鍵字從10到20。
  ee.key=10; ee.value=110; Insert(hh,&ee);
  ee.key=11; ee.value=111; Insert(hh,&ee);
  ee.key=12; ee.value=112; Insert(hh,&ee);
  ee.key=13; ee.value=113; Insert(hh,&ee);
  ee.key=14; ee.value=114; Insert(hh,&ee);
  ee.key=15; ee.value=115; Insert(hh,&ee);
  ee.key=16; ee.value=116; Insert(hh,&ee);
  ee.key=17; ee.value=117; Insert(hh,&ee);
  ee.key=18; ee.value=118; Insert(hh,&ee);
  ee.key=19; ee.value=119; Insert(hh,&ee);
 
  // 插入數據元素,關鍵字從20到30。
  ee.key=20; ee.value=120; Insert(hh,&ee);
  ee.key=21; ee.value=121; Insert(hh,&ee);
  ee.key=22; ee.value=122; Insert(hh,&ee);
  ee.key=23; ee.value=123; Insert(hh,&ee);
  ee.key=24; ee.value=124; Insert(hh,&ee);
  ee.key=25; ee.value=125; Insert(hh,&ee);
  ee.key=26; ee.value=126; Insert(hh,&ee);
  ee.key=27; ee.value=127; Insert(hh,&ee);
  ee.key=28; ee.value=128; Insert(hh,&ee);
  ee.key=29; ee.value=129; Insert(hh,&ee);
 
  // 插入數據元素,關鍵字從30到32。
  ee.key=30; ee.value=130; Insert(hh,&ee);
  ee.key=31; ee.value=131; Insert(hh,&ee);
  ee.key=32; ee.value=132; Insert(hh,&ee);
 
  printf("count=%d\n",hh->count);
  PrintTable(hh);    // 打印哈希表 
 
  Delete(hh,12);     // 刪除哈希表中關鍵字為12的數據元素。
 
  printf("count=%d\n",hh->count);
  PrintTable(hh);    // 打印哈希表 
 
  // 在哈希表中查找關鍵字18。
  Node *pp=LookUp(hh,18);
  if (pp==0) printf("LookUp(18) failed.\n");
  else printf("key=18,value=%d.\n",pp->elem.value);  
 
  // ee.key=10; strcpy(ee.value,"<no>00010<no/><name>西施</name><yz>絕世美人</yz>"); Insert(hh,&ee);
  // PrintTable(hh);    // 打印哈希表 
 
  FreeHashTable(hh);  // 銷毀哈希表 
 
  return 0;
}

關于“C語言數據結構哈希表是什么”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

泌阳县| 玛多县| 江安县| 独山县| 商城县| 刚察县| 化州市| 双流县| 从化市| 上杭县| 奈曼旗| 安达市| 安平县| 宜兰县| 湘潭市| 连山| 花垣县| 原平市| 彭山县| 广灵县| 上思县| 运城市| 东乡县| 迁安市| 阜阳市| 吉隆县| 屏东县| 永吉县| 黎川县| 枞阳县| 贵溪市| 定远县| 沭阳县| 朝阳区| 鹿泉市| 聂荣县| 正宁县| 凤凰县| 镶黄旗| 宝鸡市| 六安市|