Computer Science Algorithms in PHP

Overview

Computer Science Algorithms in PHP

Bubble Sort Usage

<?php

use CS\Sort;
use CS\Sort\BubbleSort;

(new Sort)->sort([5, 7, 3, 2, 9, 0, 1, 6, 8, 4], new BubbleSort);

Insertion Sort Usage

<?php

use \CS\Sort;
use \CS\Sort\InsertionSort;

(new Sort)->sort([5, 7, 3, 2, 9, 0, 1, 6, 8, 4], new InsertionSort);

Merge Sort Usage

<?php

use \CS\Sort;
use \CS\Sort\MergeSort;

(new Sort)->sort([5, 7, 3, 2, 9, 0, 1, 6, 8, 4], new MergeSort);

Quick Sort Usage

<?php

use \CS\Sort;
use \CS\Sort\QuickSort;

(new Sort)->sort([5, 7, 3, 2, 9, 0, 1, 6, 8, 4], new QuickSort);

Radix Sort Usage

<?php

use \CS\Sort;
use \CS\Sort\RadixSort;

(new Sort)->sort([5, 7, 3, 2, 9, 0, 1, 6, 8, 4], new RadixSort);

Linear Search Usage

<?php

use \CS\Search;
use \CS\Search\LinearSearch;

$array = [
    ['id' => 1, 'name' => 'Joe'],
    ['id' => 3, 'name' => 'Olivia'],
    ['id' => 5, 'name' => 'Emma'],
    ['id' => 6, 'name' => 'Oliver'],
    ['id' => 10, 'name' => 'Liam'],
    ['id' => 12, 'name' => 'John'],
    ['id' => 13, 'name' => 'James'],
    ['id' => 15, 'name' => 'Sophia'],
    ['id' => 17, 'name' => 'Benjamin'],
    ['id' => 18, 'name' => 'Ryan'],
    ['id' => 19, 'name' => 'Ivy'],
    ['id' => 21, 'name' => 'Alice'],
    ['id' => 23, 'name' => 'Max'],
    ['id' => 24, 'name' => 'Simon'],
];

(new Search)->sort($array, new LinearSearch);

Binary Search Usage

<?php

use \CS\Search;
use \CS\Search\BinarySearch;

$array = [
    ['id' => 1, 'name' => 'Joe'],
    ['id' => 3, 'name' => 'Olivia'],
    ['id' => 5, 'name' => 'Emma'],
    ['id' => 6, 'name' => 'Oliver'],
    ['id' => 10, 'name' => 'Liam'],
    ['id' => 12, 'name' => 'John'],
    ['id' => 13, 'name' => 'James'],
    ['id' => 15, 'name' => 'Sophia'],
    ['id' => 17, 'name' => 'Benjamin'],
    ['id' => 18, 'name' => 'Ryan'],
    ['id' => 19, 'name' => 'Ivy'],
    ['id' => 21, 'name' => 'Alice'],
    ['id' => 23, 'name' => 'Max'],
    ['id' => 24, 'name' => 'Simon'],
];

(new Search)->sort($array, new BinarySearch);
You might also like...
A status monitor for Elite Dangerous, written in PHP. Designed for 1080p screens in the four-panel-view in panel.php, and for 7 inch screens with a resolution of 1024x600 connected to a Raspberry Pi.

EDStatusPanel A status monitor for Elite Dangerous, written in PHP. Designed for 1080p screens in the four-panel-view in panel.php, and for 7 inch scr

🐘 A probe program for PHP environment (一款精美的 PHP 探針, 又名X探針、劉海探針)

Simplified Chinese | 简体中文 Traditional Chinese(Taiwan) | 正體中文(臺灣) Traditional Chinese(Hong Kong) | 正體中文(香港) Japanese | 日本語 😎 X Prober This is a probe

PHP Text Analysis is a library for performing Information Retrieval (IR) and Natural Language Processing (NLP) tasks using the PHP language

php-text-analysis PHP Text Analysis is a library for performing Information Retrieval (IR) and Natural Language Processing (NLP) tasks using the PHP l

PHP generics written in PHP

PHP generics written in PHP Require PHP = 7.4 Composer (PSR-4 Autoload) Table of contents How it works Quick start Example Features Tests How it work

PHP exercises from my course at ETEC and some of my own play-around with PHP

etec-php-exercises PHP exercises from my course at ETEC and some of my own play-around with PHP Translations: Português (BR) Projects Project Descript

GitHub action to set up PHP with extensions, php.ini configuration, coverage drivers, and various tools.
GitHub action to set up PHP with extensions, php.ini configuration, coverage drivers, and various tools.

GitHub action to set up PHP with extensions, php.ini configuration, coverage drivers, and various tools.

php-echarts is a php library for the echarts 5.0.

php-echarts 一款支持Apache EChart5.0+图表的php开发库 优先ThinkPHP5/6的开发及测试。 Apache EChart5.0已经最新发布,在视觉效果、动画效果和大数据展示方面已经远超之前的版本; 故不考虑EChart5.0之前版本的兼容问题;建议直接尝试5.0+

Minimalist PHP frame for Core-Library, for Developing PHP application that gives you the full control of your application.

LazyPHP lightweight Pre-Made Frame for Core-library Install Run the below command in your terminal $ composer create-project ryzen/lazyphp my-first-pr

Zilliqa PHP is a typed PHP-7.1+ interface to Zilliqa JSON-RPC API.
Zilliqa PHP is a typed PHP-7.1+ interface to Zilliqa JSON-RPC API.

Zilliqa PHP is a typed PHP-7.1+ interface to Zilliqa JSON-RPC API. Check out the latest API documentation. Add library in a composer.json file.

Owner
Anıl Özmen
Software Developer
Anıl Özmen
Explore , Experiment with data science and machine learning.

sodiumchloride Project name : sodium chloride objective : Explore,Experiment your data with datascience and machine learning version : beta 0.1.2 rele

sodium chloride 2 Jan 9, 2022
A plain-language, step-by-step guide for the computer novice to build their own cloud.

This is a plain-language, step-by-step guide for the computer novice wanting to build their own cloud, looking to declare independence from Google and its ilk, to save on monthly hosting fees, or just learn a new skill.

Paul Knight 25 Nov 19, 2022
Dnsmasq GUI is a simple Web GUI for editing the /etc/hosts file on a computer

dnsmasq GUI is a simple Web GUI for editing the /etc/hosts file on a computer, with the intention of using it for easily setting up results for dnsmasq use.

Alex Cheer 4 Nov 27, 2022
The Current US Version of PHP-Nuke Evolution Xtreme v3.0.1b-beta often known as Nuke-Evolution Xtreme. This is a hardened version of PHP-Nuke and is secure and safe. We are currently porting Xtreme over to PHP 8.0.3

2021 Nightly Builds Repository PHP-Nuke Evolution Xtreme Developers TheGhost - Ernest Allen Buffington (Lead Developer) SeaBeast08 - Sebastian Scott B

Ernest Buffington 7 Aug 28, 2022
A sampling profiler for PHP written in PHP, which reads information about running PHP VM from outside of the process.

Reli Reli is a sampling profiler (or a VM state inspector) written in PHP. It can read information about running PHP script from outside of the proces

null 272 Dec 22, 2022
PHP Meminfo is a PHP extension that gives you insights on the PHP memory content

MEMINFO PHP Meminfo is a PHP extension that gives you insights on the PHP memory content. Its main goal is to help you understand memory leaks: by loo

Benoit Jacquemont 994 Dec 29, 2022
A sampling profiler for PHP written in PHP, which reads information about running PHP VM from outside of the process.

Reli Reli is a sampling profiler (or a VM state inspector) written in PHP. It can read information about running PHP script from outside of the proces

null 258 Sep 15, 2022
A multithreaded application server for PHP, written in PHP.

appserver.io, a PHP application server This is the main repository for the appserver.io project. What is appserver.io appserver.io is a multithreaded

appserver.io 951 Dec 25, 2022
Easy to use utility functions for everyday PHP projects. This is a port of the Lodash JS library to PHP

Lodash-PHP Lodash-PHP is a port of the Lodash JS library to PHP. It is a set of easy to use utility functions for everyday PHP projects. Lodash-PHP tr

Lodash PHP 474 Dec 31, 2022
A PHP 5.3+ and PHP 7.3 framework for OpenGraph Protocol

Opengraph Test with Atoum cd Opengraph/ curl -s https://getcomposer.org/installer | php php composer.phar install --dev ./vendor/atoum/atoum/bin/atoum

Axel Etcheverry 89 Dec 27, 2022