算法题每日一练---第48天:汉明距离

简介: 两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。

3.png

一、问题描述


两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。

给你两个整数 xy,计算并返回它们之间的汉明距离。


题目链接:汉明距离


二、题目要求


样例 1

输入:x=1, y=4输出:2解释:1   (0001)
4   (0100)
上面的箭头指出了对应二进制位不同的位置。


样例 2

输入:x=3, y=1输出:1


考察

位运算简单题型
建议用时5~20min


三、问题分析


本题是位运算的第3题,没了解过位运算相关知识点可以看这一篇文章,讲解比较详细:

算法题每日一练---第45天:位运算


什么是汉明距离,简单来讲就是将两个10进制数字转换成2进制数字之后,统计不同位置上面1的个数,那如何将这题逐渐向位运算靠拢呢?


不同位置,啥叫不同位置,不就是如果相同位置都是1或0,那么就不计数。只有当相同位置一个为1,另一个为0时才开始计数,这不就是位运算的异或计算吗?


四、编码实现


classSolution {
public:
inthammingDistance(intx, inty) {
inti,ans=0;//初始化数据for(i=0;i<32;i++)//32位循环判断        {
if((x^y)&1<<i)//与计算并且开始查询1的个数            {
ans++;//计数器++            }
        }
returnans;//输出结果    }
};


五、测试结果12.png

相关文章
|
算法
算法题每日一练---第60天:快速幂
快速幂是一种简单而有效的小算法。
165 15
算法题每日一练---第60天:快速幂
|
存储 算法
算法题每日一练---第61天:数的幂次
给定三个正整数 N、M、P,求解N^MmodP的具体值。
112 8
算法题每日一练---第61天:数的幂次
|
存储 算法 测试技术
算法题每日一练---第62天:Pow(x, n)
实现 pow(x, n) ,即计算 x 的 n 次幂函数(即,x^n)
176 6
算法题每日一练---第62天:Pow(x, n)
|
算法
算法题每日一练---第58天:错误的集合
集合 s 包含从 1 到 n 的整数。
148 2
算法题每日一练---第58天:错误的集合
|
算法
算法题每日一练---第78天:二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target
168 1
算法题每日一练---第78天:二分查找
|
存储 算法
|
算法
算法题每日一练---第76天:丑数 l
丑数 就是只包含质因数 2、3 和 5 的正整数。
138 1
算法题每日一练---第76天:丑数 l
|
算法 C++
算法题每日一练---第67天:无重复字符的最长子串
给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
115 0
算法题每日一练---第67天:无重复字符的最长子串
|
算法
算法题每日一练---第65天:螺旋矩阵 II
给你一个正整数 n ,生成一个包含 1 到 n2 所有元素
106 1
算法题每日一练---第65天:螺旋矩阵 II

热门文章

最新文章