20200202数据结构和算法 之用哈希表实现DNA检测

可以使用哈希表来存储色盲基因库数据,通过哈希函数把 4 位色盲基因映射到哈希表中,大大提高检索的效率

#include<Windows.h>
#include<iostream>
#include<stdio.h>
using namespace std;
#define isEqual(a, b)  (0==strcmp((const char*)a,(const char*)b))

#define DEFAULT_SIZE 128

typedef struct _listNode {
   
	struct _listNode* next;
	void* key;
	void* data;
}listNode;

typedef listNode* list;
typedef listNode* element;

typedef struct _hashTable {
   
	int tableSize;
	list* theLists;
}hashTable;

hashTable* initHash(int tableSize);
int hashFunction(void* key, int tableSize);//哈希函数
element findElement(hashTable* &hashTable, void* key);
bool insertElement(hashTable* &hashTable, void* key, void* value);
bool deleteElement(hashTable* &hastTable, void* key);
unsigned int SDBMHash(void* key);
void destroyHash(hashTable* &hashTable);

int main() {
   
	const char* str[] = {
    "ABCD","BDCD","ACDB","BACD" };
	char tester[] = "ABDCDC";
	char tmp[5] = {
   0};
	strncpy_s(tmp,sizeof(tmp), tester + 1, 4);

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值