Hash算法

Hash去除重复字符串:

#include <iostream>
#include <windows.h>
#include <random>
#include <time.h>
using namespace std;    

#define MAX 10000
#define MOD 9991

char * Hash[MAX][20];
int len[MAX];

int _hash(char *str){
	register int hash=0;
	while(int ch=(int)*str++){
		//hash=hash*31+ch;
		hash=hash<<7+hash<<1+hash+ch;
		hash%=MOD;
	}
	return hash%MOD;
}

void Test()//测试程序
{
	//freopen("C:\\in.txt","r",stdin);
	FILE *fp1=fopen("C:\\a.txt","r");
	FILE *fp2=fopen("C:\\b.txt","w");
	char str[20];
	memset(len,0,sizeof(len));
	while(~fscanf(fp1,"%s",str)){
		int pos=_hash(str);
		bool flag=false;
		for(int i=0;i<len[pos];i++){
			if(strcmp(str,Hash[pos][i])==0){
				flag=true;
				break;
			}
		}
		if(!flag){
			Hash[pos][len[pos]]=new char[20];
			int i=0;
			while(str[i]!='\0'){
				Hash[pos][len[pos]][i]=str[i];
				i++;
			}
			Hash[pos][len[pos]++][i]='\0';
			fprintf(fp2,"%s ",str);
		}
	}
	fclose(fp1);
	fclose(fp2);
}
     
int main(void)    
{    
    LARGE_INTEGER BegainTime ;    
    LARGE_INTEGER EndTime ;    
    LARGE_INTEGER Frequency ;    
    QueryPerformanceFrequency(&Frequency);    
    QueryPerformanceCounter(&BegainTime) ;    
    
    //要测试的代码放在这里   
    Test();   
     
    QueryPerformanceCounter(&EndTime);   
    
    //输出运行时间(单位:s)   
    cout << "运行时间(单位:s):" <<(double)( EndTime.QuadPart - BegainTime.QuadPart )/ Frequency.QuadPart <<endl;    
    
    //system("pause") ;    
    return 0 ;    
}



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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值