*推薦使用FNV1算法*@algorithmNone*@authorGoodzzp2006-11-20*@lastEditGoodzzp2006-11-20*@editDetailCreate*/publicclassHashAlgorithms{/***加法hash*@paramkey字符串*@paramprime一個(gè)質(zhì)數(shù)*@returnhash結(jié)果*/publicstaticintadditiveHash(S" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

java實(shí)現(xiàn)hash算法

系統(tǒng) 1728 0
Java代碼
??
/**??
* Hash算法大全<br>??
* 推薦使用FNV1算法??
* @algorithm None??
* @author Goodzzp 2006-11-20??
* @lastEdit Goodzzp 2006-11-20???
* @editDetail Create??
*/??
public class HashAlgorithms???
{???
/**??
* 加法hash??
* @param key 字符串??
* @param prime 一個(gè)質(zhì)數(shù)??
* @return hash結(jié)果??
*/??
public static int additiveHash(String key, int prime)???
{???
?? int hash, i;???
?? for (hash = key.length(), i = 0; i < key.length(); i++)???
??? hash += key.charAt(i);???
?? return (hash % prime);???
}???
??
/**??
* 旋轉(zhuǎn)hash??
* @param key 輸入字符串??
* @param prime 質(zhì)數(shù)??
* @return hash值??
*/??
public static int rotatingHash(String key, int prime)???
{???
?? int hash, i;???
?? for (hash=key.length(), i=0; i<key.length(); ++i)???
???? hash = (hash<<4)^(hash>>28)^key.charAt(i);???
?? return (hash % prime);???
//?? return (hash ^ (hash>>10) ^ (hash>>20));???
}???
??
// 替代:???
// 使用:hash = (hash ^ (hash>>10) ^ (hash>>20)) & mask;???
// 替代:hash %= prime;???
??
??
/**??
* MASK值,隨便找一個(gè)值,最好是質(zhì)數(shù)??
*/??
static int M_MASK = 0x8765fed1;???
/**??
* 一次一個(gè)hash??
* @param key 輸入字符串??
* @return 輸出hash值??
*/??
public static int oneByOneHash(String key)???
{???
?? int?? hash, i;???
?? for (hash=0, i=0; i<key.length(); ++i)???
?? {???
???? hash += key.charAt(i);???
???? hash += (hash << 10);???
???? hash ^= (hash >> 6);???
?? }???
?? hash += (hash << 3);???
?? hash ^= (hash >> 11);???
?? hash += (hash << 15);???
//?? return (hash & M_MASK);???
?? return hash;???
}???
??
/**??
* Bernstein's hash??
* @param key 輸入字節(jié)數(shù)組??
* @param level 初始hash常量??
* @return 結(jié)果hash??
*/??
public static int bernstein(String key)???
{???
?? int hash = 0;???
?? int i;???
?? for (i=0; i<key.length(); ++i) hash = 33*hash + key.charAt(i);???
?? return hash;???
}???
??
//???
//// Pearson's Hash???
// char pearson(char[]key, ub4 len, char tab[256])???
// {???
//?? char hash;???
//?? ub4 i;???
//?? for (hash=len, i=0; i<len; ++i)????
//???? hash=tab[hash^key[i]];???
//?? return (hash);???
// }???
??
//// CRC Hashing,計(jì)算crc,具體代碼見其他???
// ub4 crc(char *key, ub4 len, ub4 mask, ub4 tab[256])???
// {???
//?? ub4 hash, i;???
//?? for (hash=len, i=0; i<len; ++i)???
//???? hash = (hash >> ^ tab[(hash & 0xff) ^ key[i]];???
//?? return (hash & mask);???
// }???
??
/**??
* Universal Hashing??
*/??
public static int universal(char[]key, int mask, int[] tab)???
{???
?? int hash = key.length, i, len = key.length;???
?? for (i=0; i<(len<<3); i+=8)???
?? {???
???? char k = key[i>>3];???
???? if ((k&0x01) == 0) hash ^= tab[i+0];???
???? if ((k&0x02) == 0) hash ^= tab[i+1];???
???? if ((k&0x04) == 0) hash ^= tab[i+2];???
???? if ((k&0x08) == 0) hash ^= tab[i+3];???
???? if ((k&0x10) == 0) hash ^= tab[i+4];???
???? if ((k&0x20) == 0) hash ^= tab[i+5];???
???? if ((k&0x40) == 0) hash ^= tab[i+6];???
???? if ((k&0x80) == 0) hash ^= tab[i+7];???
?? }???
?? return (hash & mask);???
}???
??
/**??
* Zobrist Hashing??
*/????
public static int zobrist( char[] key,int mask, int[][] tab)???
{???
?? int hash, i;???
?? for (hash=key.length, i=0; i<key.length; ++i)???
???? hash ^= tab[i][key[i]];???
?? return (hash & mask);???
}???
??
// LOOKUP3????
// 見Bob Jenkins(3).c文件???
??
// 32位FNV算法???
static int M_SHIFT = 0;???
/**??
* 32位的FNV算法??
* @param data 數(shù)組??
* @return int值??
*/??
??? public static int FNVHash(byte[] data)???
??? {???
??????? int hash = (int)2166136261L;???
??????? for(byte b : data)???
??????????? hash = (hash * 16777619) ^ b;???
??????? if (M_SHIFT == 0)???
??????????? return hash;???
??????? return (hash ^ (hash >> M_SHIFT)) & M_MASK;???
??? }???
??? /**??
???? * 改進(jìn)的32位FNV算法1??
???? * @param data 數(shù)組??
???? * @return int值??
???? */??
??? public static int FNVHash1(byte[] data)???
??? {???
??????? final int p = 16777619;???
??????? int hash = (int)2166136261L;???
??????? for(byte b:data)???
??????????? hash = (hash ^ b) * p;???
??????? hash += hash << 13;???
??????? hash ^= hash >> 7;???
??????? hash += hash << 3;???
??????? hash ^= hash >> 17;???
??????? hash += hash << 5;???
??????? return hash;???
??? }???
??? /**??
???? * 改進(jìn)的32位FNV算法1??
???? * @param data 字符串??
???? * @return int值??
???? */??
??? public static int FNVHash1(String data)???
??? {???
??????? final int p = 16777619;???
??????? int hash = (int)2166136261L;???
??????? for(int i=0;i<data.length();i++)???
??????????? hash = (hash ^ data.charAt(i)) * p;???
??????? hash += hash << 13;???
??????? hash ^= hash >> 7;???
??????? hash += hash << 3;???
??????? hash ^= hash >> 17;???
??????? hash += hash << 5;???
??????? return hash;???
??? }???
??
??? /**??
???? * Thomas Wang的算法,整數(shù)hash??
???? */????
??? public static int intHash(int key)???
??? {???
????? key += ~(key << 15);???
????? key ^= (key >>> 10);???
????? key += (key << 3);???
????? key ^= (key >>> 6);???
????? key += ~(key << 11);???
????? key ^= (key >>> 16);???
????? return key;???
??? }???
??? /**??
???? * RS算法hash??
???? * @param str 字符串??
???? */??
??? public static int RSHash(String str)???
??? {???
??????? int b??? = 378551;???
??????? int a??? = 63689;???
??????? int hash = 0;???
??
?????? for(int i = 0; i < str.length(); i++)???
?????? {???
????????? hash = hash * a + str.charAt(i);???
????????? a??? = a * b;???
?????? }???
??
?????? return (hash & 0x7FFFFFFF);???
??? }???
??? /* End Of RS Hash Function */??
??
??? /**??
???? * JS算法??
???? */??
??? public static int JSHash(String str)???
??? {???
?????? int hash = 1315423911;???
??
?????? for(int i = 0; i < str.length(); i++)???
?????? {???
????????? hash ^= ((hash << 5) + str.charAt(i) + (hash >> 2));???
?????? }???
??
?????? return (hash & 0x7FFFFFFF);???
??? }???
??? /* End Of JS Hash Function */??
??
??? /**??
???? * PJW算法??
???? */??
??? public static int PJWHash(String str)???
??? {???
??????? int BitsInUnsignedInt = 32;???
??????? int ThreeQuarters???? = (BitsInUnsignedInt * 3) / 4;???
??????? int OneEighth???????? = BitsInUnsignedInt / 8;???
??????? int HighBits????????? = 0xFFFFFFFF << (BitsInUnsignedInt - OneEighth);???
??????? int hash????????????? = 0;???
??????? int test????????????? = 0;???
??
?????? for(int i = 0; i < str.length();i++)???
?????? {???
????????? hash = (hash << OneEighth) + str.charAt(i);???
??
????????? if((test = hash & HighBits) != 0)???
????????? {???
???????????? hash = (( hash ^ (test >> ThreeQuarters)) & (~HighBits));???
????????? }???
?????? }???
??
?????? return (hash & 0x7FFFFFFF);???
??? }???
??? /* End Of P. J. Weinberger Hash Function */??
??
??? /**??
???? * ELF算法??
???? */??
??? public static int ELFHash(String str)???
??? {???
??????? int hash = 0;???
??????? int x??? = 0;???
??
?????? for(int i = 0; i < str.length(); i++)???
?????? {???
????????? hash = (hash << 4) + str.charAt(i);???
????????? if((x = (int)(hash & 0xF0000000L)) != 0)???
????????? {???
???????????? hash ^= (x >> 24);???
???????????? hash &= ~x;???
????????? }???
?????? }???
??
?????? return (hash & 0x7FFFFFFF);???
??? }???
??? /* End Of ELF Hash Function */??
??
??? /**??
???? * BKDR算法??
???? */??
??? public static int BKDRHash(String str)???
??? {???
??????? int seed = 131; // 31 131 1313 13131 131313 etc..???
??????? int hash = 0;???
??
?????? for(int i = 0; i < str.length(); i++)???
?????? {???
????????? hash = (hash * seed) + str.charAt(i);???
?????? }???
??
?????? return (hash & 0x7FFFFFFF);???
??? }???
??? /* End Of BKDR Hash Function */??
??
??? /**??
???? * SDBM算法??
???? */??
??? public static int SDBMHash(String str)???
??? {???
??????? int hash = 0;???
??
?????? for(int i = 0; i < str.length(); i++)???
?????? {???
????????? hash = str.charAt(i) + (hash << 6) + (hash << 16) - hash;???
?????? }???
??
?????? return (hash & 0x7FFFFFFF);???
??? }???
??? /* End Of SDBM Hash Function */??
??
??? /**??
???? * DJB算法??
???? */??
??? public static int DJBHash(String str)???
??? {???
?????? int hash = 5381;???
??
?????? for(int i = 0; i < str.length(); i++)???
?????? {???
????????? hash = ((hash << 5) + hash) + str.charAt(i);???
?????? }???
??
?????? return (hash & 0x7FFFFFFF);???
??? }???
??? /* End Of DJB Hash Function */??
??
??? /**??
???? * DEK算法??
???? */??
??? public static int DEKHash(String str)???
??? {???
??????? int hash = str.length();???
??
?????? for(int i = 0; i < str.length(); i++)???
?????? {???
????????? hash = ((hash << 5) ^ (hash >> 27)) ^ str.charAt(i);???
?????? }???
??
?????? return (hash & 0x7FFFFFFF);???
??? }???
??? /* End Of DEK Hash Function */??
??
??? /**??
???? * AP算法??
???? */??
??? public static int APHash(String str)???
??? {???
??????? int hash = 0;???
??
?????? for(int i = 0; i < str.length(); i++)???
?????? {???
????????? hash ^= ((i & 1) == 0) ? ( (hash << 7) ^ str.charAt(i) ^ (hash >> 3)) :???
?????????????????????????????????? (~((hash << 11) ^ str.charAt(i) ^ (hash >> 5)));???
?????? }???
??
//?????? return (hash & 0x7FFFFFFF);???
?????? return hash;???
??? }???
??? /* End Of AP Hash Function */??
???????
??? /**??
???? * JAVA自己帶的算法??
???? */??
??? public static int java(String str)???
{???
?? int h = 0;???
?? int off = 0;???
?? int len = str.length();???
?? for (int i = 0; i < len; i++)???
?? {???
??? h = 31 * h + str.charAt(off++);???
?? }???
?? return h;???
}???
???????
??? /**??
???? * 混合hash算法,輸出64位的值??
???? */??
????? public static long mixHash(String str)???
???? {???
??? long hash = str.hashCode();???
???? hash <<= 32;???
???? hash |= FNVHash1(str);???
??? return hash;???
???? }?


本文來自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://www.java3z.com/cwbwebhome/article/article5/51002.html

java實(shí)現(xiàn)hash算法


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 国产欧美一区二区三区免费 | 午夜精品久久久久 | 亚洲成人网在线 | www.黄色片| 久久伊人中文字幕有码 | 亚洲欧美国产另类 | 国产色婷婷视频在线观看 | 中文字幕日韩高清 | 欧美黑人巨大3dvideo | 久草香蕉在线视频 | 亚洲欧美人成综合在线最新 | 狠狠色噜噜狠狠狠狠狠色综合久久 | 亚洲一级在线观看 | 欧美日韩在线看 | 国产国语一级a毛片高清视频 | 久久午夜宅男免费网站 | 欧美第一页在线观看 | 久久精品国产一区二区三区肥胖 | 久久精品一区二区免费看 | 欧美jizzhd精品欧美另类 | 操bb影院 | 黄色毛片网站 | 欧美日韩国产一区三区 | 欧美日韩专区 | 在线 色 | 五月四房婷婷 | 欧洲美女高清一级毛片 | 国产精品欧美亚洲韩国日本久久 | 最新精品亚洲成a人在线观看 | 亚洲第一区视频在线观看 | 亚洲综合色丁香麻豆 | 午夜精品久久久久久毛片 | 亚洲精品一二三区-久久 | 午夜视频国产 | 久久一本久综合久久爱 | 国产精欧美一区二区三区 | aaa影院| 久久精品国产屋 | 奇米在线视频777 | 91青草久久久久久清纯 | 亚洲黄网视频 |