我有一个值为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++;
}
}
解决方法:
试试这个
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());
标签:java
来源: https://codeday.me/bug/20190722/1507796.html