2020-11-07 05:48:07 +02:00
|
|
|
import { copy } from "./object";
|
|
|
|
|
|
|
|
export function listMergeSorted(list1: any[] = [], list2: any[] = []) {
|
|
|
|
const result = copy(list1);
|
|
|
|
|
2020-12-11 04:06:16 +02:00
|
|
|
const minId = list1.length ? list1[list1.length - 1] : 0xFFFFFFFF;
|
2020-11-07 05:48:07 +02:00
|
|
|
for(let i = 0; i < list2.length; i++) {
|
2020-12-11 04:06:16 +02:00
|
|
|
if(list2[i] < minId) {
|
2020-11-07 05:48:07 +02:00
|
|
|
result.push(list2[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2021-01-10 20:10:02 +04:00
|
|
|
export const accumulate = (arr: number[], initialValue: number) => arr.reduce((acc, value) => acc + value, initialValue);
|
|
|
|
|
|
|
|
export function findAndSpliceAll<T>(array: Array<T>, verify: (value: T, index: number, arr: typeof array) => boolean) {
|
|
|
|
const out: typeof array = [];
|
|
|
|
let idx = -1;
|
|
|
|
while((idx = array.findIndex(verify)) !== -1) {
|
|
|
|
out.push(array.splice(idx, 1)[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return out;
|
|
|
|
}
|