定制 krak/sorts 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

krak/sorts

最新稳定版本:v0.1.0

Composer 安装命令:

composer require krak/sorts

包简介

A collection of sorting algorithms implemented in php

README 文档

README

A library for sort algorithms in php. Typically, you'd want to use php's c sorting functions, however, php lacks a stable sorting algorithms which can be useful in certain situations. In addition, this provides the opportunity for the community to implement many other custom sorts that could be useful in specific scenarios.

Installation

Installation via composer:

{
    "repositories": [
        {
            "type": "vcs",
            "url": "https://gitlab.bighead.net/bighead/krak-sorts.git"
        }
    ],
    "require": {
        "krak/sorts": "~0.1"
    }
}

Sorting Algorithms

Identity Sort

The identity sort does absolutely nothing. It just leaves the array untouched. This is useful for testing.

Insertion Sort

This implements the insertion sort algorithm. This is a stable sort. It's memory efficient and performs well on mostly sorted arrays and/or small datasets

Merge Sort

This implements the merge sort algorithm. Our implementation is a little more space efficient than most. However, it's space efficient relative to php's standards not C's.

Mock Sort

<?php

$sort = new Sorts\MockSort($data);
$sort->sort($other_data, Sorts\PHPCMP);

$other_data === $data; // true

This just assigns the data to be sorted to the data passed in. Useful for testing.

StableSort

$sort = new Sorts\StableSort(new Sorts\InsertionSort(), new Sorts\MergeSort(), 20);

This sort will take in two stable sorts (like insertion and merge) and will apply one or the other based off of the cutoff value. If the size of the array to sort is less than the cutoff, it will use the first sort, else it will use the latter sort. This works well when you use it on insertion and merge because insertion will typically outperform merge sort when under 20 or so elements.

Usage

There are two different API's for the sorting library.

Object Oriented Interface

Every sort is defined as class that implements the following interface:

<?php

namespace Krak\Sorts;

interface Sort
{
    /**
     * @param &$vals an array like object
     * @param string|\Closure $cmp a comparison function
     */
    public function sort(&$vals, $cmp);
}

You can create an instane of any of these to perform a sort.

new IdentitySort()
new InsertionSort()
new MergeSort()
new MockSort(mixed $data_to_assign)
new StableSort(Sort $few_sort, Sort $many_sort, int $cutoff_value)

Functional Interface

Or you can use the functional interface which is much cleaner to work with.

void sorts\stable(mixed &$data, $cmp = sorts\PHPCMP)
void sorts\insertion(mixed &$data, $cmp = sorts\PHPCMP)
void sorts\merge(mixed &$data, $cmp = sorts\PHPCMP)

There are three constants defined for sorting:

  • PHPCMP this uses the < and > to get apply a comparison on arbitrary objects that support those operators
  • STRCMP this is the strcmp function
  • INTCMP this is just the difference between $a and $b

You can view the source code for references on these comparison functions.

Comparison Functions

A valid comparison is any variable that can be invoked with these (). So if $cmp($a, $b) doesn't throw an error, then it's a valid comparison. These comparisons are exactly compatible (the same as) the php comparison definitions

统计信息

  • 总下载量: 64
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-05-07