我编写了一个新程序来比较 2 个两位数无符号整数。通过汉明距离进行比较。但我的算法并不完美。你能告诉我这段代码有什么问题吗:(非常感谢!!

这是我的计数方法;

int countHammDist(unsigned int n, unsigned int m)
{
int i=0;
unsigned int count = 0 ;
for(i=0; i<8; i++){
if( n&1 != m&1 ) {
    count++;
    }
n >>= 1;
m >>= 1;

}
return count;
}

a 和 b 8 位二进制文​​件。

 PrintInBinary(a);
 PrintInBinary(b);

 printf("\n %d", countHammDist(a,b));

让我向您展示输出;

Enter two unsigned integers (0-99): 55 64
Your choices are 55 and 64
Number A: 00110111
Number B: 01000000
Hamming distance is ; 5
有帮助吗?

解决方案

在 n&1 和 m&1 两边加上括号。

if ((n&1) != (m&1))

http://ideone.com/F7Kyzg

这是因为 != 在 & 之前: http://www.swansontec.com/sopc.html

其他提示

你需要转变 m 也可以比较正确的位。

无论平等测试是否通过,您都需要移动它们。(将班次移到内部外部 } )

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top