android汉明距离,C++实例之海明距离问题解析

以下是关于C++实例之海明距离问题解析,希望可以加深大家对于C++实例之海明距离问题的理解,下面就一起来看看C++实例之海明距离问题解析方面的内容吧。

【海明距离介绍 】

在信息领域,两个长度相等的字符串 的海明距离是在相同位置上不同的字符的个数,也就是将一个字符串替换成另一个字符串需要的替换的次数。

例如:

xxxxyy 和xxxxzz 的海明距离是2;

111100 和 111111 的海明距离是2;

对于二进制数字来说,海明距离的结果相当于a^b结果中1的个数。

【字符串】

C++ Code

/*

version: 1.0

author: hellogiser

date: 2014/5/30

*/

// hamming distance of two strings

unsigned hamdist(const char *str1, const char *str2)

{

// aaabb aaacc

if (str1 == NULL || str2 == NULL)

return 0;

int len1 = strlen(str1);

int len2 = strlen(str2);

if (len1 != len2)

return 0;

unsigned dist = 0;

while(*str1 && *str2)

{

dist += (*str1 != *str2) ? 1 : 0;

str1++;

str2++;

}

return dist;

}

【数字】

C++ Code

/*

version: 1.0

author: hellogiser

date: 2014/5/30

*/

// hamming distance of two integer 0-1 bits

unsigned hamdist(unsigned x, unsigned y)

{

// 11111 11100

unsigned dist = 0, val = x ^ y; // XOR

// Count the number of set bits

while(val)

{

++dist;

val &= val - 1;

}

return dist;

}

以上就是对于C++实例之海明距离问题解析的全部内容叙述,更多有关C++实例之海明距离方面的知识,请继续关注拓胜科技c++技术资讯频道,或者咨询拓胜网络客服了解c++培训方面的问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值