# quickselect **Repository Path**: mirrors_mourner/quickselect ## Basic Information - **Project Name**: quickselect - **Description**: A fast selection algorithm in JavaScript. - **Primary Language**: Unknown - **License**: ISC - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-09-25 - **Last Updated**: 2026-03-01 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README ## quickselect [![Node](https://github.com/mourner/quickselect/actions/workflows/node.yml/badge.svg)](https://github.com/mourner/quickselect/actions/workflows/node.yml) [![Simply Awesome](https://img.shields.io/badge/simply-awesome-brightgreen.svg)](https://github.com/mourner/projects) A tiny and fast [selection algorithm](https://en.wikipedia.org/wiki/Selection_algorithm) in JavaScript (specifically, [Floyd-Rivest selection](https://en.wikipedia.org/wiki/Floyd%E2%80%93Rivest_algorithm)). ```js quickselect(array, k[, left, right, compareFn]); ``` Rearranges items so that all items in the `[left, k]` are the smallest. The `k`-th element will have the `(k - left + 1)`-th smallest value in `[left, right]`. - `array`: the array to partially sort (in place) - `k`: middle index for partial sorting (as defined above) - `left`: left index of the range to sort (`0` by default) - `right`: right index (last index of the array by default) - `compareFn`: compare function Example: ```js const arr = [65, 28, 59, 33, 21, 56, 22, 95, 50, 12, 90, 53, 28, 77, 39]; quickselect(arr, 8); // arr is [39, 28, 28, 33, 21, 12, 22, 50, 53, 56, 59, 65, 90, 77, 95] // ^^ middle index ```