唯一哈希,最多4个字符?

mem*_*und 5 java algorithm hash

String如果哈希值不超过4个字符,那么创建哈希值的最佳方法是什么?这4个字符可能只是小写字母或数字?

我想要哈希的字符串有1-255个字符.我知道在没有碰撞的情况下创建4-char哈希可能是不可能的.但是,如果我有一个很好的哈希就可以使碰撞最小化就足够了.

我试过的是CRC16CCITT从这里:http: //introcs.cs.princeton.edu/java/61data/CRC16CCITT.java

public class CRC16CCITT { 

    public static void main(String[] args) { 
        int crc = 0xFFFF;          // initial value
        int polynomial = 0x1021;   // 0001 0000 0010 0001  (0, 5, 12) 

        // byte[] testBytes = "123456789".getBytes("ASCII");

        byte[] bytes = args[0].getBytes();

        for (byte b : bytes) {
            for (int i = 0; i < 8; i++) {
                boolean bit = ((b   >> (7-i) & 1) == 1);
                boolean c15 = ((crc >> 15    & 1) == 1);
                crc <<= 1;
                if (c15 ^ bit) crc ^= polynomial;
            }
        }

        crc &= 0xffff;
        StdOut.println("CRC16-CCITT = " + Integer.toHexString(crc));
    }

}
Run Code Online (Sandbox Code Playgroud)

但这会产生太多的碰撞.有更好的算法吗?

wal*_*len 0

您将“十六进制数字”误认为“字符”:

    int crc = 0xFFFF;          // initial value
Run Code Online (Sandbox Code Playgroud)

那只有 2 个字节(0xFF只是 1 个字节)。对于 4 个 ANSI 字符的 CRC,您需要 4 个字节 ( 0xFFFFFFFF)。
您必须调整其余的代码才能使用双倍长度,如果您不知道如何操作,请发表评论。

PS:您可以使用少于 4 个字节来完成此操作,但这会使事情变得不必要的复杂化。