c语言练习题80:汉明距离

本文介绍了如何使用异或和位运算(包括r^(r-1))来计算两个整数之间的汉明距离。算法步骤包括异或两个数得到r,然后通过while循环累加r与(r-1)的非零操作次数直到r为0。
摘要由CSDN通过智能技术生成

汉明距离

题⽬描述:

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

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

⽰例 1:

输⼊:x = 1, y = 4

输出:2

解释:

1 (0 0 0 1)

4 (0 1 0 0)

       ↑     ↑

• ⽰例 2:

输⼊:

x = 3, y = 1

输出:1

解法(位运算):

异或(^)运算:将两个⼆进制数按位进⾏⽐较,若相应位不同则该位结果为1,否则结果为0。

例 如,

对于⼆进制数1010和1101,它们的异或结果为0111。

本题利⽤异或(^)运算符将两数异或后,求得其中1的个数即可。

为了更快地统计某个数 r 中1的个数,可以使⽤ r&(r-1) 运算,它可以直接将 r 中最右边的1变为 0。这是因为 r-1 操作将r的最右边的1变为0,并将1后⾯的0变为1,所以 r 和 r-1 在这些位上⼀ 定有其中⼀个含有0。

例如:(与c语言练习题30相似)

r=110100 , r-1=110011 , r&(r-1)=110000 。

因此,进⾏按位与运算后,结果相当于将 r 最右边的1变为0。接下来,我们只需要记录 r 不为0时 r&(r-1) 可以操作的次数即可。

算法思路:

1. 定义⼀个变量 r ,将其初始化为 x 和 y 的异或值;

2. 定义⼀个变量 n ,将其初始化为0;

3. 当 r 不为0时, n 的值加⼀并执⾏⼀次r=r&(r-1)操作。

4. 返回 n 。

int hammingDistance(int x, int y) {
	//⾸先进⾏两数异或运算求得r
	int r = x ^ y;
	int n = 0;
	//当r不为0时记录⼀次并且执⾏⼀次r&(r-1)操作
	while (r) {
		n++;
		r = r & (r - 1);
	}
	return n;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值