我正在尝试使用有关 int 数组的信息填充 BitSet 数组
//ar is a SIZE*SIZE 1-D int array, SIZE is a constant
//decare BitSet array
BitSet bs[] = new BitSet[SIZE];
//initialize BitSet array
for (BitSet x:bs)
x = new BitSet();
//populate BitSet array
for (int i = 0 ; i < ar.length ; i++)
if (ar[i] > 0)
bs[(i/SIZE)].set(SIZE-(i%SIZE));
最后一行似乎是问题所在,但我看不出逻辑有什么问题。有任何想法吗?
为了更清楚一点,如果我有一个像 0,3,4,5,0,1,0,0,1,2,7,0,2,3,0,3,2,0 这样的数组, 0,0,2,1,5,8,0,0,0,0,0,1,0,0,0,6,0,0
我想得到一个可以表示为 011101,001110,110110,001111,000001,000100 的位集数组