哈希查找

// HSearch.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include<iostream>
#define MAXSIZE 5 //#define 后面不加;他妹的我竟然忘了
using namespace std;

typedef struct HashNode
{
 int data;
 HashNode *next;
} *HashList;//散列链表的每个结点的数据结构

inline int f(int i)// f(i)是满足 f(i)<MAXSIZE 的任意可行合理的函数
{
 return (i%(MAXSIZE));
}

template < int n >
void HashInsert(int (&A)[n], HashList HashA[])
{
 HashNode *p, *q;
 for (int j=0;j<(MAXSIZE);++j)
 {
  HashA[j]=NULL;
 }

 for (int i = 0; i < n; i++)
 {
  p = new HashNode;
  p->data = A[i];
  p->next=NULL;
  int j = f(A[i]);
  if (HashA[j] == NULL)
   HashA[j] = p;
  else
  {
   q = HashA[j];
   while ((q->next) != NULL)
    q = q->next;
   q->next = p;
  }
 }
}

template <int n>
int HashSearch(int (&A)[n],HashList HashA[], int b)
{
 HashNode *p;
 HashInsert(A, HashA);
 p = HashA[f(b)];
 while (p->next!= NULL)
 {
  if (p->data == b)
   return (1);
  else
   p = p->next;
 }
 return 0;
}

int main()
{
 HashList HashA[MAXSIZE];
 int a[10] = { 9 ,3 ,4 ,6,12,15,6,7,9,4};
 int result=HashSearch(a, HashA,9);
 cout<<(result?"success":"failure")<<endl;
 return 0;
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值