2022-10-17 15:48:02 +03:00

32 lines
889 B
TypeScript

export function areEqual<T>(arr1: ReadonlyArray<T>, arr2: ReadonlyArray<T>) {
return arr1.length === arr2.length && arr1.every((value, index) => value === arr2[index]);
}
export function difference<T>(arr1: ReadonlyArray<T>, arr2: ReadonlyArray<T>) {
if (arr1.length !== arr2.length) return null;
const changes = [];
// eslint-disable-next-line unicorn/no-for-loop
for (let i = 0; i < arr1.length; i += 1) {
if (arr1[i] !== arr2[i]) {
changes.push(i);
}
}
return changes;
}
export function shift<T>(arr: Array<T>, n: number) {
if (arr.length === 0) return arr;
const shiftNumber = n % arr.length;
if (shiftNumber === 0) return arr;
return [...arr.slice(-shiftNumber, arr.length), ...arr.slice(0, -shiftNumber)];
}
export function isSorted(arr: Array<number>) {
return arr.every((value, index, array) => !index || array[index - 1] <= value);
}