123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- /**
- * Copyright (c) 2017 mol* contributors, licensed under MIT, See LICENSE file for more info.
- *
- * @author David Sehnal <david.sehnal@gmail.com>
- */
- import * as Sort from '../util/sort'
- function shuffle<T>(data: T, len: number, clone: (s: T) => T, swap: Sort.Swapper = Sort.arraySwap) {
- const a = clone(data);
- for (let i = len - 1; i > 0; i--) {
- const j = Math.floor(Math.random() * (i + 1));
- swap(a, i, j);
- }
- return a;
- }
- function shuffleArray(data: any[]) {
- return shuffle(data, data.length, t => [...t]);
- }
- describe('qsort-array asc', () => {
- const data0 = new Array(50);
- for (let i = 0; i < data0.length; i++) data0[i] = i;
- const data1 = [1, 1, 2, 2, 3, 3, 4, 4, 4, 6, 6, 6];
- function test(name: string, data: any[], randomize: boolean) {
- it(name, () => {
- // [ 3, 1, 6, 4, 4, 6, 4, 2, 6, 1, 2, 3 ];
- if (randomize) {
- for (let i = 0; i < 10; i++) {
- expect(Sort.sortArray(shuffleArray(data))).toEqual(data);
- }
- } else {
- expect(Sort.sortArray([...data])).toEqual(data);
- }
- });
- }
- test('uniq', data0, false);
- test('uniq shuffle', data0, true);
- test('rep', data1, false);
- test('rep shuffle', data1, true);
- })
- describe('qsort-array generic', () => {
- const data0 = new Array(50);
- for (let i = 0; i < data0.length; i++) data0[i] = i;
- const data1 = [1, 1, 2, 2, 3, 3, 4, 4, 4, 6, 6, 6];
- function test(name: string, data: any[], randomize: boolean) {
- it(name, () => {
- // [ 3, 1, 6, 4, 4, 6, 4, 2, 6, 1, 2, 3 ];
- if (randomize) {
- for (let i = 0; i < 10; i++) {
- expect(Sort.sort(shuffleArray(data), 0, data.length, Sort.arrayLess, Sort.arraySwap)).toEqual(data);
- }
- } else {
- expect(Sort.sort([...data], 0, data.length, Sort.arrayLess, Sort.arraySwap)).toEqual(data);
- }
- });
- }
- test('uniq', data0, false);
- test('uniq shuffle', data0, true);
- test('rep', data1, false);
- test('rep shuffle', data1, true);
- })
- describe('qsort-dual array', () => {
- const len = 3;
- const data = { xs: [0, 1, 2], ys: ['x', 'y', 'z'] };
- const cmp: Sort.Comparer<typeof data> = (data, i, j) => data.xs[i] - data.xs[j];
- const swap: Sort.Swapper<typeof data> = (data, i, j) => { Sort.arraySwap(data.xs, i, j); Sort.arraySwap(data.ys, i, j); }
- const clone = (d: typeof data) => ({ xs: [...d.xs], ys: [...d.ys] })
- function test(name: string, src: typeof data, randomize: boolean) {
- it(name, () => {
- // [ 3, 1, 6, 4, 4, 6, 4, 2, 6, 1, 2, 3 ];
- if (randomize) {
- for (let i = 0; i < 10; i++) {
- expect(Sort.sort(shuffle(src, len, clone, swap), 0, len, cmp, swap)).toEqual(data);
- }
- } else {
- expect(Sort.sort(clone(src), 0, len, cmp, swap)).toEqual(data);
- }
- });
- }
- test('sorted', data, false);
- test('shuffled', data, true);
- })
|