mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-07-05 08:16:50 +08:00
merge: add alphanumerical sort (#872)
* alphanumerical sort * [/pull/872] add description to alphanumerical sort * [/pull/872] add description to localCompare fn * [/pull/872] code formatter
This commit is contained in:
38
Sorts/AlphaNumericalSort.js
Normal file
38
Sorts/AlphaNumericalSort.js
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
/*
|
||||||
|
https://en.wikipedia.org/wiki/Natural_sort_order
|
||||||
|
|
||||||
|
In computing, natural sort order (or natural sorting) is the ordering of strings in alphabetical order,
|
||||||
|
except that multi-digit numbers are treated atomically, i.e., as if they were a single character. Natural sort order
|
||||||
|
has been promoted as being more human-friendly ("natural") than machine-oriented, pure alphabetical sort order.[1]
|
||||||
|
|
||||||
|
For example, in alphabetical sorting, "z11" would be sorted before "z2" because the "1" in the first string is sorted as smaller
|
||||||
|
than "2", while in natural sorting "z2" is sorted before "z11" because "2" is treated as smaller than "11".
|
||||||
|
|
||||||
|
Alphabetical sorting:
|
||||||
|
1.z11
|
||||||
|
2.z2
|
||||||
|
|
||||||
|
Natural sorting:
|
||||||
|
1. z2
|
||||||
|
2. z11
|
||||||
|
|
||||||
|
P.S. use this function, as there are a lot of implementations on the stackoverflow and other forums, but many of them don't work correctly (can't pass all my tests)
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
const alphaNumericalSort = (a, b) => {
|
||||||
|
/*
|
||||||
|
https://developer.mozilla.org/ru/docs/Web/JavaScript/Reference/Global_Objects/String/localeCompare
|
||||||
|
|
||||||
|
The localeCompare() method returns a number indicating whether a reference string comes before, or after, or is the same as the given string in sort order.
|
||||||
|
|
||||||
|
The new locales and options arguments let applications specify the language whose sort order should be used and customize the behavior of the function.
|
||||||
|
In older implementations, which ignore the locales and options arguments, the locale and sort order used are entirely implementation-dependent.
|
||||||
|
Syntax:
|
||||||
|
localeCompare(compareString, locales, options)
|
||||||
|
|
||||||
|
*/
|
||||||
|
return a.localeCompare(b, undefined, { numeric: true })
|
||||||
|
}
|
||||||
|
|
||||||
|
export { alphaNumericalSort }
|
39
Sorts/test/AlphaNumericalSort.test.js
Normal file
39
Sorts/test/AlphaNumericalSort.test.js
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
import { alphaNumericalSort } from '../AlphaNumericalSort'
|
||||||
|
|
||||||
|
describe('alphaNumericalComparer', () => {
|
||||||
|
test('given array of eng symbols return correct sorted array', () => {
|
||||||
|
const src = ['b', 'a', 'c']
|
||||||
|
src.sort(alphaNumericalSort)
|
||||||
|
expect(src).toEqual(['a', 'b', 'c'])
|
||||||
|
})
|
||||||
|
|
||||||
|
test('given array of numbers return correct sorted array', () => {
|
||||||
|
const src = ['15', '0', '5']
|
||||||
|
src.sort(alphaNumericalSort)
|
||||||
|
expect(src).toEqual(['0', '5', '15'])
|
||||||
|
})
|
||||||
|
|
||||||
|
test('correct sort with numbers and strings', () => {
|
||||||
|
const src = ['3', 'a1b15c', 'z', 'a1b14c']
|
||||||
|
src.sort(alphaNumericalSort)
|
||||||
|
expect(src).toEqual(['3', 'a1b14c', 'a1b15c', 'z'])
|
||||||
|
})
|
||||||
|
|
||||||
|
test('correct sort with long numbers', () => {
|
||||||
|
const src = ['abc999999999999999999999999999999999cba', 'abc999999999999999999999999999999990cba', 'ab']
|
||||||
|
src.sort(alphaNumericalSort)
|
||||||
|
expect(src).toEqual(['ab', 'abc999999999999999999999999999999990cba', 'abc999999999999999999999999999999999cba'])
|
||||||
|
})
|
||||||
|
|
||||||
|
test('correct sort with z prefix', () => {
|
||||||
|
const src = ['z', 'abc003def', 'abc1def', 'a']
|
||||||
|
src.sort(alphaNumericalSort)
|
||||||
|
expect(src).toEqual(['a', 'abc1def', 'abc003def', 'z'])
|
||||||
|
})
|
||||||
|
|
||||||
|
test('correct sort with other language', () => {
|
||||||
|
const src = ['а10б', 'а2б', 'в10г', 'в05г']
|
||||||
|
src.sort(alphaNumericalSort)
|
||||||
|
expect(src).toEqual(['а2б', 'а10б', 'в05г', 'в10г'])
|
||||||
|
})
|
||||||
|
})
|
Reference in New Issue
Block a user