gmp_hamdist

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

gmp_hamdistРасстояние Хэмминга

Описание

int gmp_hamdist ( GMP $a , GMP $b )

Возвращает расстояние Хэмминга для чисел a и b. Оба операнда должны быть неотрицательными.

Список параметров

a

Или ресурс resource GMP числа в PHP 5.5 и ранее, или объект класса GMP в PHP 5.6 и новее, или числовая строка, при условии, что ее можно преобразовать в число позже.

Должно быть неотрицательным.

b

Или ресурс resource GMP числа в PHP 5.5 и ранее, или объект класса GMP в PHP 5.6 и новее, или числовая строка, при условии, что ее можно преобразовать в число позже.

Должно быть неотрицательным.

Возвращаемые значения

Ресурс resource GMP числа в PHP 5.5 и ранее, или объект класса GMP в PHP 5.6 и новее.

Примеры

Пример #1 Пример использования gmp_hamdist()

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

/* расстояние Хэмминга эквивалентно: */
echo gmp_popcount(gmp_xor($ham1$ham2)) . "\n";
?>

Результат выполнения данного примера:

6
6

Смотрите также

  • gmp_popcount() - Количество единиц в двоичной записи числа
  • gmp_xor() - Побитовое исключающее ИЛИ

Коментарии

Автор:
For those without gmp support :

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

And if you are not sure if your strings have equal length :

$hamming_distance = count(array_diff_assoc(str_split(str_pad($string1,strlen($string2)-strlen($string1),' ')), str_split(str_pad($string2,strlen($string1)-strlen($string2),' '))));
2018-04-16 08:41:00
http://php5.kiev.ua/manual/ru/function.gmp-hamdist.html
<?php
$hamdist 
gmp_hamdist(-100, -10); // 4
$hamdist gmp_hamdist(10010);  // 5
?>

The function works great with negative numbers.
2021-03-11 13:14:43
http://php5.kiev.ua/manual/ru/function.gmp-hamdist.html

    Поддержать сайт на родительском проекте КГБ