我有一个布尔数组(长度= 2),我想要将其转换为一个整数,以便整数内的各个位代表布尔数组中的值:
[false, false] = 0
[false, true] = 1
[true, false] = 2
[true, true] = 3
答案 0 :(得分:13)
这将有效:
int n = (a[0] ? 2 : 0) + (a[1] ? 1 : 0);
如果您想要更通用的解决方案:
int n = 0, l = a.length;
for (int i = 0; i < l; ++i) {
n = (n << 1) + (a[i] ? 1 : 0);
}
答案 1 :(得分:9)
任意长度数组的通用方法(尽管只有最后32个元素有所不同,因为整数是32位):
int booleansToInt(boolean[] arr){
int n = 0;
for (boolean b : arr)
n = (n << 1) | (b ? 1 : 0);
return n;
}
答案 2 :(得分:1)
int i = (array[0] ? 2 : 0) + (array[1] ? 1 : 0);
长度的一般解决方案!= 2:
public static void main(String[] args) {
boolean[] array = {true, true, false};
int number = 0;
int j = array.length - 1;
for (int i = 0; i < array.length; i++) {
if (array[i])
number += 1 << j--;
}
}
答案 3 :(得分:0)
int number = 0;
for(int i = array.length - 1; i >= 0; i--)
{
if(array[i])
{
int exponent = (array.length - 1 - i)
number += Math.pow( 2, exponent );
}
}