461. Hamming Distance and 477. Total Hamming Distance in Python
题目:
The Hamming distance between two integers is the number of positions at which the corresponding bits are different.
Given two integers x
and y
, calculate the Hamming distance.
Note:
0 ≤ x
, y
< 231.
Example:
- Input: x = 1, y = 4
- Output: 2
- Explanation:
- 1 (0 0 0 1)
- 4 (0 1 0 0)
- ↑ ↑
- The above arrows point to positions where the corresponding bits are different.
Example:
- Input: 4, 14, 2
- Output: 6
- Explanation: In binary representation, the 4 is 0100, 14 is 1110, and 2 is 0010 (just
- showing the four bits relevant in this case). So the answer will be:
- HammingDistance(4, 14) + HammingDistance(4, 2) + HammingDistance(14, 2) = 2 + 2 + 2 = 6.
Note:
- Elements of the given array are in the range of
0
to10^9
- Length of the array will not exceed
10^4
代码:
这两周比较慢,都没有做题,赶紧做两道。这两个题目比较像,就放在一起吧。汉明距离,就是把数字变成二进制,看有多少为不一样,不一样的个数就是汉明距离。
所以,第一题,仅仅比较两个数字,我就用了常人都能想到的方法,转换成二进制字符串,遍历比较。唯一注意的就是将较短的字符串前面加0补足和长的相同位数。
- def hammingDistance(self, x, y):
- """
- :type x: int
- :type y: int
- :rtype: int
- """
- str1 = bin(x)[2:]
- str2 = bin(y)[2:]
- if len(str1) < len(str2):
- str1 = ''*(abs(len(str2)-len(str1)))+str1
- else:
- str2 = '' * (abs(len(str2) - len(str1))) + str2
- res = 0
- for i in range(0,len(str1)):
- if not str1[i:i+1] == str2[i:i+1]:
- res += 1
- return res
这个题通过了,但第二个题目要求给出一个字符串,两两求出汉明距离,然后相加。于是,我接着上题的函数,增加了一个遍历,O(n^2):
- def totalHammingDistance(self, nums):
- """
- :type nums: List[int]
- :rtype: int
- """
- if not nums:
- return 0
- res = 0
- new_nums = sorted(nums)
- print sorted(set(nums))
- for i in range(len(new_nums)):
- for j in new_nums[i+1:]:
- print new_nums[i],j
- print self.hammingDistance(new_nums[i],j)
- res += self.hammingDistance(new_nums[i],j)
- return res
逻辑是没错,但不用想,leetcode中当然超时,会有一个包含1000个7、8位数字的列表去测试。唉,没办法,想不出来,百度了一下。这个汉明距离,其实可以通过每个bit位上面数字0的个数和1的个数相乘的结果,相加求得。等于逐一遍历列表中每个数字的每个bit位,所有bit位遍历一遍。
- def totalHammingDistance2(self, nums):
- """
- :type nums: List[int]
- :rtype: int
- """
- if not nums:
- return 0
- res = 0
- lists = []
- nums.sort()
- for i in nums:
- temp = list(bin(i)[2:])
- temp.reverse()
- lists.append(temp)
- for i in range(len(lists[-1])):
- count_0, count_1 = 0, 0
- for element in lists:
- # print element
- if len(element)-1 < i:
- count_0 += 1
- elif element[i] == '':
- count_0 += 1
- elif element[i] == '':
- count_1 += 1
- # print count_0,count_1
- res += count_0 * count_1
- return res
试了下,果然没问题!:)
461. Hamming Distance and 477. Total Hamming Distance in Python的更多相关文章
- [LeetCode] 477. Total Hamming Distance 全部汉明距离
The Hamming distance between two integers is the number of positions at which the corresponding bits ...
- 477. Total Hamming Distance总的二进制距离
[抄题]: The Hamming distance between two integers is the number of positions at which the correspondin ...
- [LeetCode] 477. Total Hamming Distance(位操作)
传送门 Description The Hamming distance between two integers is the number of positions at which the co ...
- 【LeetCode】477. Total Hamming Distance 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 位运算 日期 题目地址:https://leetco ...
- 461. Hamming Distance + 477. Total Hamming Distance
▶ 与 Hamming 距离相关的两道题. ▶ 461. 求两个数 x 与 y 的哈夫曼距离. ● 代码,4 ms,对 x 和 y 使用异或,然后求值为 1 的位的个数. class Solutio ...
- LeetCode "477. Total Hamming Distance"
Fun one.. the punch line of this problem is quite common in Bit related problems on HackerRank - vis ...
- 477. Total Hamming Distance
class Solution { public: int totalHammingDistance(vector<int>& nums) { ; ; i < ; i++) { ...
- 477 Total Hamming Distance 汉明距离总和
两个整数的 汉明距离 指的是这两个数字的二进制数对应位不同的数量.计算一个数组中,任意两个数之间汉明距离的总和.示例:输入: 4, 14, 2输出: 6解释: 在二进制表示中,4表示为0100,14表 ...
- [LeetCode] Total Hamming Distance 全部汉明距离
The Hamming distance between two integers is the number of positions at which the corresponding bits ...
随机推荐
- jquery中ajax用return来返回值无效
jquery中,ajax返回值,有三种写法,只有其中一种是成功的 /** * async:false,同步调用 * 返回1:2 * 失败 * 分析:ajax内部是一个或多个定义的函数,ajax中ret ...
- 记一周cdqz训练
#include <cstdio> using namespace std; int main(){ puts("转载请注明出处:http://www.cnblogs.com/w ...
- c# 判断访问来源是否来自手机
public Boolean IsMobileDevice() { string[] mobileAgents =new []{ "iphone", "android&q ...
- bat基础
首先所有命令在cmd命令行中都能找到说明: 例如 想知道type用法 输入type /? 其他命令都一样 type [drive:][path] filename 显示文本文件内容 虽然有点鸡肋 1 ...
- 矢量图绘制工具Svg-edit调整画布的大小
矢量图绘制工具Svg-edit调整画布的大小 ------------------------------ ------------------------
- Netty源码分析之客户端启动过程
一.先来看一下客户端示例代码. public class NettyClientTest { public void connect(int port, String host) throws Exc ...
- 学习篇:TypeCodes的2015年博客升级记
原文: https://typecodes.com/mix/2015updateblog.html 2015年博客升级记 作者:vfhky | 时间:2015-05-23 17:25 | 分类:mix ...
- ip扫描
ipscan24 Advanced IP Scanner http://www.advanced-ip-scanner.com/cn/
- 深入理解javascript原型和闭包 (转)
该教程绕开了javascript的一些基本的语法知识,直接讲解javascript中最难理解的两个部分,也是和其他主流面向对象语言区别最大的两个部分--原型和闭包,当然,肯定少不了原型链和作用域链.帮 ...
- 视图控制器的View整体上移问题
最近我朋友代码出现一个问题,我看了下,发现已经是适配iOS那时候的问题了 如果你准备将你的老的 iOS 6 app 迁移到 iOS 7 上,那么你必须注意了.当你的老的 app 在 iOS 7 设备上 ...