每日一题:461. 汉明距离

80 阅读1分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第24天,点击查看活动详情

一、题目描述:

461. 汉明距离 - 力扣(LeetCode)

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

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

示例 1:

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

示例 2:

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

提示:

  • 0 <= x, y <= 2^31 - 1

二、思路分析:

先将x和y转化成为二进制表示(主要利用while循环判断x或y是否整除2,如果能则取出余数,再将余数存到v1和v2中),然后判断v1和v2的大小,将小的扩展成大的大小,然后再将两个容器中的相同位置的元素相加,如果相同位置上的元素不相同,则结果肯定为1,因此只要统计结果为1的元素个数即为汉明距离

三、AC 代码:

class Solution {
public:
    int hammingDistance(int x, int y) 
    {
       vector<int>v1;//用于存储x的二进制表示
	   vector<int>v2;//用于存储y的二进制表示
	   vector<int>vs;//用于存储v1和v2中相同位置的元素相加后的结果
	   int count = 0;//计数器,后续用于统计容器中值为1的个数
	   while (x / 2 != 0)
	  {
		v1.push_back(x % 2);
		x /= 2;
	  }
	   v1.push_back(x % 2);//由于while循环跳出条件为商为0,但实际上还能再取余数,因此还需再取余一次
	   while (y / 2 != 0)
	  {
		v2.push_back(y % 2);
		y /= 2;
	  }
	    v2.push_back(y % 2);
	   if (v1.size() >= v2.size())//判断v1和v2的容量大小,取大的容量来初始化小的
	  {
		v2.resize(v1.size(), 0);
	  }
	   else
	  {
		v1.resize(v2.size(), 0);
	  }
	   for (int i = 0; i < v1.size(); i++)
	  {
		vs.push_back(v1[i] + v2[i]);//计算两容器中相同位置上的元素之和
	  }
	   for (int j = 0; j < vs.size(); j++)
	  {
		  if (vs[j] == 1)//如果两相同位置上的元素之和等于1,则表示两元素值不相等
		 {
			  count++;
		 }
	  }
	return count;
    }
};