2

除了汉明距离,我什么都有。我不断收到错误“int() 无法使用显式基数转换非字符串”

这是我的代码:

def int2bin(n):                                
    if n:
        bits = []
        while n:
            n,remainder = divmod(n, 2)
            bits.insert(0, remainder)
        return bits
    else: return [0]

def bin2gray(bits):                  
    return bits[:1] + [i ^ ishift for i, ishift in zip(bits[:-1], bits[1:])]

def hamming(a,b):                        
    assert len(a) == len(b)
    count,z = 0,int(a,2)^int(b,2)
    while z:
        count += 1
        z &= z-1 
    return count

def main():
    a = int(input("Positive integer 1: "))        
    b = int(input("Positive integer 2: "))
    print('int:%2i    binary:%12r    BRGC:%12r' %    
          ( a,
            int2bin(a),
        bin2gray(int2bin(a))
           ))
    print('int:%2i    binary:%12r    BRGC:%12r' %
          ( b,
            int2bin(b),
        bin2gray(int2bin(b))
           ))
    print('hamming|%2     %12r        &12r' %
          (hamming(int2bin(a),int2bin(b)),
           hamming(bin2gray(int2bin(a)),bin2gray(int2bin(b)))
           ))

main()

输出应该看起来像

int: 5 binary: [1, 0, 1] brgc: [1, 1, 1]    
int: 6 binary: [1, 1, 0] brgc: [1, 0, 1]    
hamming            2               1

请帮忙!

4

3 回答 3

7

试试这个实现(a并且b应该是整数):

def hamming(a, b):
    return bin(a^b).count('1')

在这里,我异a或和得到二进制,其中一个代表和b之间的差异。比我只数一个。ab

于 2015-11-23T15:57:00.070 回答
0

此代码计算两个可能很长的字符串的汉明距离。

def hammingDist(s1,s2):
if type(s1) is str: s1=s1.encode()
if type(s2) is str: s2=s2.encode()

count=0
for b1,b2 in zip(s1,s2):
    a=b1^b2
    while a>0:
        count+= a & 1
        a=a >> 1
return count
于 2019-02-12T05:33:47.297 回答
0

在函数hamming中,

count,z = 0,int(a,2)^int(b,2)

看起来您正在将整数列表作为第一个参数 ( aand b) 传递给函数int()。第二个参数是您的明确基础。你不能这样做。

尝试用a''.join(str(el) for el in a)相同的替换b

或者,您可以将函数替换为int2bin直接format(n, 'b')获取二进制字符串。

于 2015-11-12T03:17:11.813 回答