按位不对一串位操作

时间:2013-12-30 06:16:27

标签: java

我有一个值为0111000000的字符串。如何对此字符串执行按位运算?

如果我将其转换为整数,请使用~运算符并将其转换回二进制字符串,结果字符串有额外的位。我希望输出完全是1000111111

以下代码工作正常,但这不是一个好方法。还有另一种更好的方法吗?

   String bstr="";
   while(m!=str.length())
   {             
        char a=str.charAt(m);
        if(a=='1')
        {
             a='0';
             bstr=bstr+a;
             m++;   
        }
        else
        {
             a='1'; 
             bstr=bstr+a;
             m++;
         }
}

6 个答案:

答案 0 :(得分:4)

试试这个

    char[] a = s.toCharArray();
    for(int i = 0; i < a.length; i++) {
        a[i] = a[i]=='0' ? '1' : '0';
    }
    s = new String(a);

这也可以正常使用

    int i = ~Integer.parseInt(s, 2);
    String tmp = Integer.toBinaryString(i);
    s = tmp.substring(tmp.length()- s.length());

答案 1 :(得分:1)

跟踪位串中的位数。转换为整数并使用~value操作翻转位后,使用位掩码删除不需要的1高端位。

比如说你的位串有一个固定的10位。然后,您可以使用以下代码屏蔽掉不需要的高端位:value & 0x2ff

如果位串中的位数是可变的:

value & ((1 << nBits) - 1)

答案 2 :(得分:1)

来自普通语的

StringUtils.replaceChars可能对此有所帮助:

StringUtils.replaceChars("0111000000", "01", "10");

答案 3 :(得分:1)

您应该使用字符串构建器,这样您就可以更改单个位而无需创建许多垃圾字符串。您也可以使用XOR翻转单个位:

b ^= 1;

适用于数字的二进制和ASCII值。

答案 4 :(得分:1)

也许这会奏效:

String result = Integer.toBinaryString(~(Integer.parseInt("0111000000",2)));

将二进制String转换为int,使用按位非运算符反转,然后转换回二进制字符串。

答案 5 :(得分:1)

您可以使用XOR操作

执行此操作
public String xorOperation(String value) {
    String str1 = value;
    long l = Long.parseLong(str1, 2);
    String str2 = "";
    for (int i = 0; i < str1.length(); i++) {
        str2 = str2 + "1";
    }
    long n = Long.parseLong(str2, 2);
    long num = l ^ n;
    String bininaryString = Long.toBinaryString(num);
    System.out.println(bininaryString);
    return bininaryString;
}