gmp_hamdist

(PHP 4 >= 4.0.4, PHP 5, PHP 7, PHP 8)

gmp_hamdist汉明距离

描述

gmp_hamdist(GMP|int|string $num1, GMP|int|string $num2): int

返回 num1num2 之间的汉明距离。两个操作数都应为非负数。

参数

num1

一个 GMP 对象、一个 int 或一个数字 string.

它应该是正数。

num2

一个 GMP 对象、一个 int 或一个数字 string.

它应该是正数。

返回值

num1num2 之间的汉明距离,以 int 形式。

示例

示例 #1 gmp_hamdist() 示例

<?php
$ham1
= gmp_init("1001010011", 2);
$ham2 = gmp_init("1011111100", 2);
echo
gmp_hamdist($ham1, $ham2) . "\n";

/* hamdist 等效于: */
echo gmp_popcount(gmp_xor($ham1, $ham2)) . "\n";
?>

以上示例将输出

6
6

参见

添加注释

用户贡献注释 2 个注释

4
Bas Vijfwinkel
6 年前
对于没有 gmp 支持的人

$hamming_distance = count(array_diff_assoc(str_split($string1), str_split($string2)));

如果你不确定你的字符串是否长度相等

$hamming_distance = count(array_diff_assoc(str_split(str_pad($string1,strlen($string2)-strlen($string1),' ')), str_split(str_pad($string2,strlen($string1)-strlen($string2),' '))));
-1
grabzila at gmail dot com
3 年前
<?php
$hamdist
= gmp_hamdist(-100, -10); // 4
$hamdist = gmp_hamdist(100, 10); // 5
?>

该函数在负数上运行良好。
To Top