const isSorted = arr => {
let direction = -(arr[0] - arr[1]);
for (let [i, val] of arr.entries()) {
direction = !direction ? -(arr[i - 1] - arr[i]) : direction;
if (i === arr.length - 1) return !direction ? 0 : direction;
else if ((val - arr[i + 1]) * direction > 0) return 0;
}
};
isSorted([0, 1, 2, 2]); // 1
isSorted([4, 3, 2]); // -1
isSorted([4, 3, 5]); // 0
'Dev. Web > 자주 쓰는 스크립트 모음' 카테고리의 다른 글
join - 배열 구분자 (0) | 2019.06.16 |
---|---|
countBy - 그룹별 카운트 (0) | 2019.06.16 |
intersection - 배열 교집합 (0) | 2019.06.14 |
forEachRight - 반복해서 콜백 처리 (0) | 2019.06.14 |
키보드로 이동 가능한 리스트 (0) | 2019.01.23 |