-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.js
53 lines (47 loc) · 1.47 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
let Grid = require('./grid');
let sortGrid = require('./sort-grid').sortGrid;
let walkGrid = require('./walk-grid').walkGrid;
function memoize(memo,array,sortedArray){
let key = array.join('-');
memo[key] = sortedArray;
return memo;
}
function sort(array, memo = {}){
let key = array.join('-');
if(memo[key]){
return memo[key];
}
let grid = new Grid(array);
if(grid.width === 2){
let sortedGridArray = walkGrid(sortGrid(grid));
return sortedGridArray;
}
let counter = 0;
while(counter <= grid.width){
// sort rows
Object.keys(grid.rows).forEach( row => {
if(row % 2 == 0){
grid.rows[row] = sort(grid.rows[row]);
} else {
grid.rows[row] = sort(grid.rows[row]).reverse();
}
//console.log('grid row', row, grid.rows[row])
});
counter++;
// sort columns
let sortedColumns = [];
for(let i = 0; i < grid.length; i++){
let unSortedColumn = grid.getColumn(i);
//console.log('column', i, unSortedColumn)
let soretdColumn = sort(unSortedColumn);
//console.log('sortedColumn', soretdColumn);
sortedColumns.push(soretdColumn);
}
grid.setRowsFromColumns(sortedColumns);
counter++;
}
let sortedArray = walkGrid(grid);
memoize(memo, array, sortedArray);
return sortedArray;
}
module.exports = sort;