1

私はこのプログラムを使用しています:

private static char[] toCharArray(final BitSet bs){    
    final int length = bs.length();     
    final char[] arr = new char[length];     
    for(int i = 0; i < length; i++){         
        arr[i] = bs.get(i) ? '1' : '0';
    }     
    return arr;
} 

BitSetobjをchar[]配列に変換します。(ゼロの追加)配列にいくつかの変更を加えた後、それをobjchar[]に戻したいと思います。BitSet方法はありますか...

4

2 に答える 2

1

なぜこれを行うのかよくわかりませんが、方法を逆にしてみませんか?

private static BitSet toBitset(final char[] entries){
        final int length = entries.length;
        BitSet bs = new BitSet(length);
        for(int i = 0; i < length; i++){
                bs.set(i, entries[i] == '1');
        }
        return bs;
}

編集:メソッドを修正したかったようですので、char配列を特定のサイズに強制する方法は1つしか考えられませんが、最後に追加するゼロの数を知る必要があるため、書き直しましたこのようなあなたの方法:

private static char[] toCharArray(final BitSet bs, int expectedBits){
        if(expectedBits < bs.length()){
            expectedBits = bs.length();
        }
        final char[] arr = new char[expectedBits];
        for(int i = 0; i < expectedBits; i++){
            arr[i] = bs.get(i) ? '1' : '0';
        }
        return arr;
    }

ビットマップの使用に関する問題は、「1」のみを格納するため、ビットセットの最後のエントリは常に「1」になり、長さは常にビットセットの最後の「1」を参照することです。

例えば:

 BitSet bs = new BitSet();
        for(int i = 0; i < 1000; i++){
            bs.set(i, false);
        }
 System.out.println(bs.length()); 

「0」を出力しますが、

BitSet bs = new BitSet();
bs.set(10001, true); 
System.out.println(bs.length()); 

10002を印刷します。

これはあなたを助けるかもしれません(しかしあなたはそれに応じて上記のメソッドを編集する必要があるでしょう):

class FixedBitSet extends BitSet {

    private int maxLength = 0;

    public int maxLength(){
        return maxLength;
    }

    @Override
    public void set(int bitIndex, boolean value) {
        super.set(bitIndex, value);
        if(bitIndex > maxLength){
            maxLength = bitIndex;
        }
    }

}
于 2011-03-23T15:46:09.287 に答える
0

同様のタスクを完了するためにUnitTestを実行します。次のことを思いついた:

BitSet bs = new BitSet(testArrayChar.length);

for (int y=0; y<testArrayChar.length; y++)
{
    if(testArrayChar[y]=='0')
    {
        bs.set(y, false);
    }
    else if(testArrayChar[y]=='1')
    {
        bs.set(y, true);
    }
}

文字が0または1以外の場合、スロー例外を追加できます。

于 2016-11-14T23:42:07.150 に答える