gpt4 book ai didi

Java-位操作

转载 作者:行者123 更新时间:2023-12-02 00:16:20 25 4
gpt4 key购买 nike

我有以下 Java 代码:

long a = Long.parseLong("11001100", 2);
long b = Long.parseLong("11000000", 2);
int npos = 0 ;
int pos = 0 ;
long n = ~(a ^ b) ;
int cnt = 0;
while (n != 0) {
pos++ ;
if ((n & 3) == 3) cnt++; // count how many matches
else{
npos = pos ; // position that not matched also giving wrong which should be 2 nd position.
}
n >>>= 2;
}

System.out.println(npos + " " + cnt) ; // also print which two bits are not matched i.e. 00 and 11

我试图找出两个整数中有多少个两位序列匹配。我还想找出哪两位不匹配。有人可以帮我怎么做吗?

PS:我的原始代码中没有字符串,只有整数。因此,我无法进行字符串操作。

编辑:

long a = Long.parseLong("11000100", 2);
long b = Long.parseLong("11000000", 2);
long mask = 0x03;
int npos = 0 ;
int cnt = 0;
long p1 = 0;
long p2 = 0;
for (int pos = 0; pos < 64; pos++, mask <<= 2) {

if ((a & mask) == (b & mask)) {
cnt++; // count how many matches
} else {
npos = pos ; // *last* position that did not match
p1 = (a & mask) ; // two bits that not matched
p2 = (b & mask) ; // two bits that not matched
}
}

System.out.println(npos + " " + cnt + " " + p1 + " " + p2) ; // also print which two bits are not matched i.e. 00 and 01

最佳答案

您将整数解析为以 10 为基数的数字,您可能希望将它们解析为二进制整数,为此,请使用具有基数参数的方法:

long a = Long.parseInt("11001100", 2);
long b = Long.parseInt("11000000", 2);

使用掩码运行循环比较 2 个值可能会更容易:

long mask = 0x03;
int npos = 0 ;
int cnt = 0;

for (int pos = 0; pos < 32; pos++, mask <<= 2) {

if ((a & mask) == (b & mask)) {
cnt++; // count how many matches
} else {
npos = pos ; // *last* position that did not match
}
}

关于Java-位操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11852164/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com