A small PHP package to help you perform a search in large scale arrays with a dramatically improved performance.
You can install the package via composer:
composer require ezzaze/binary-searchuse Ezzaze\BinarySearch\BinarySearch;
$haystack = range(1,1000000);
$result1 = BinarySearch::exists(500, $haystack); //true
$result2 = BinarySearch::exists(0, $haystack); //falseIf you have an already pre-sorted array you can skip the sorting before search by supplying false to the 3rd parameter
use Ezzaze\BinarySearch\BinarySearch;
$haystack = range(1,1000000);
$result = BinarySearch::exists(500, $haystack, false);The package can also be used to search for multi-demensional array within another array as shown below
use Ezzaze\BinarySearch\BinarySearch;
$haystack = array_chunk(range(1,1000000), 2);
$result1 = BinarySearch::exists([500,501], $haystack); //true
$result2 = BinarySearch::exists([501, 502], $haystack); //falsecomposer testPlease see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.