zoukankan      html  css  js  c++  java
  • 20190503-汉明距离

    难度分类

    简单

    题目描述

    两个整数之间的汉明距离指的是这两个数字对应二进制位不同的位置的数目。给出两个整数 x 和 y,计算它们之间的汉明距离

    注意:

    0 ≤ x, y < 231.

    示例:

    输入: x = 1, y = 4

    输出: 2

    解释:

    1   (0 0 0 1)

    4   (0 1 0 0)

           ↑   ↑

    上面的箭头指出了对应二进制位不同的位置。

    算法

    1. 获取x,y的二进制的字符串

    2. 使用zfill函数将x,y的二进制字符串中较短的字符串的长度用‘0’填充成与较长位字符串长度一样长

    3. 使用zip函数一一遍历对比

    考点

    1. 十进制与二进制的转换bin函数
    2. Zfill函数
    3. zip函数

    代码

    def hammingDistance(self, x, y):
            #step1:转换二进制
            binary_x = bin(x)[2:]
            binary_y = bin(y)[2:]
            #step2:调整长度
            if len(binary_x)>len(binary_y):
                binary_y = binary_y.zfill(len(binary_x))
            else:
                binary_x = binary_x.zfill(len(binary_y))
            result=0
            #step3:按位对比,统计不同的位数
            for i,j in zip(binary_x,binary_y):
                if i!=j:
                    result+=1

    进阶算法

    统计二进制位不同的可使用二进制异或运算,然后统计结果二进制的1的个数。异或运算即二进制下不进位加法,二进制的异或运算法则如下:

    1. 0+0=0

    2. 0+1=1

    3. 1+0=1

    4. 1+1=0

    示例中0001^0100=0101,统计0101中1的个数即为二进制位不同的总数

    进阶考点

    1. 异或运算
    2. str.count()函数

    进阶代码

    def hammingDistance(self, x, y):
            """
            :type x: int
            :type y: int
            :rtype: int
            """
            return bin(x^y).count('1')

    附-十进制转换二进制代码

     def binary_transfer(x):
                result = ''
                while x!=0:
                    result+=str(x%2)
                    x = x//2
                return result[::-1]
  • 相关阅读:
    Nginx使用
    MySQL 分区
    php PDO预处理
    php
    php
    linux 下编译安装MySQL
    php 工厂模式
    MySQL 权限管理
    hadoop集群安装20181016(20111130:前面太忙,没有写完,后面继续)
    JavaScript函数参数翻转——连接多个数组——zip、zipwith
  • 原文地址:https://www.cnblogs.com/hyj691001/p/10806160.html
Copyright © 2011-2022 走看看