OR按位运算的数学方程?

时间:2013-04-24 00:44:52

标签: java math bit-manipulation bitwise-operators bitwise-or

是否存在使用*+-/等基本运算符的逐位OR运算的数学表达式?我正在寻找的一个例子(换班)n<<a变成n*Math.pow(2,a)

1 个答案:

答案 0 :(得分:1)

可以建议一个算法解决方案

public static void main(String[] args) throws Exception {
    byte a = 0x14;
    byte b = 0x1;
    int c = or(a, b);
    System.out.println(Integer.toHexString(c));
}

static int or(byte a, byte b) {
    int c = 0;
    for (int i = 0; i < 8; i++) {
        if (bit(a, i) != 0 || bit(b, i) != 0) {
            c += Math.pow(2, i);
        }
    }
    return c;
}

static int bit(int x, int i) {
    return x / (int) Math.pow(2, i) % 2;
}

它可以转换为单行表达式,但它太长了

int c = (a % 2 != 0 ? 1 : b % 2 !=0 ? 1 : 0) + (a % 4 / 2 != 0 ? 2 : b % 4 / 2 !=0 ? 2 : 0) ... 

这是计算位的方式

int a0 = a % 2;
int a1 = a % 4 / 2;
int a2 = a % 8 / 4;
int a3 = a % 16 / 8;
int a4 = a % 32 / 16;
...