二进制Divison Java实施



这可能是一个奇怪的问题,但是我还没有发现任何二进制划分Java实现浏览了Internet。我将其用于CRC16编码,因此转换为十进制不是解决方案。我了解纸上的方法,但是我是一个初学者,因为这很重要,所以我不想把它弄错。我唯一发现的是使用二进制划分的cod.google.com上的crc.java,但是即使我只使用其中的部门部分(删除其他部分),我也没有获得理想的值。

有人可以向我展示它的Java实现吗?我非常感谢!预先感谢

我发现的代码:

公共类CRC { 私人字符串数据,除数;

public CRC(String d, String di) {
    this.data = d;
    this.divisor = di;
}
public String getRemainder(String data, String divisor) {
    int x = 1, z = divisor.length(), j = 0, i;
    String data2 = "", strOfZeros = "";
    int y = divisor.length() - 1;
    /* This is to get correct amount of zero's onto the end of the data */
    while (y > 0) {
        data += "0";
        y--;
    }
    // Main part of method, this is the long division of Binary numbers.
    needToExit: for (i = x, j = 1; i < z && z <= data.length(); i++, j++) {
        if (z == data.length() && data2.charAt(0) == '1') {
            strOfZeros = "";
            for (i = 1; i < divisor.length(); i++) {    
                if (data2.charAt(i) == divisor.charAt(i))
                    strOfZeros += '0';
                else
                    strOfZeros += '1';
            }
            data2 = strOfZeros;
            break needToExit;
        }
        if (data.charAt(i) == divisor.charAt(j))
            data2 += "0";
        else
            data2 += "1";
        if (i == divisor.length() - 1) {
            data2 += data.charAt(z);
            x++;
            z++;
            // i = x;
            j = 0;
            // when first bit is a 0
            while (data2.charAt(0) != '1' && i == divisor.length() - 1) {
                for (i = 1; i < divisor.length(); i++) {
                    if (data2.charAt(i) == '0')
                        strOfZeros += "0";
                    else
                        strOfZeros += "1";
                }
                strOfZeros += data.charAt(z);
                data2 = strOfZeros;
                strOfZeros = "";
                x++;
                z++;
                i = x;
            }
        }
    }
    return data2;
}
public String getDataPlusCRC(String data){
    String str = data.concat(getRemainder(this.data, this.divisor));
    return str;
}

}

当我尝试将数字划分时,getRemainder()方法给了我不好的结果。而且这部分不是必需的,因为它需要CRC。

while (y > 0) {
            data += "0";
            y--;
        }

biginteger可以做基础2师;

    BigInteger divisor = new BigInteger("10", 2);
    BigInteger dividend = new BigInteger("100", 2);
    BigInteger result = dividend.divide(divisor);
    System.out.println(result.toString(2));

最新更新