Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,851 questions

51,772 answers

573 users

How to check if an array is all increasing or decreasing and the gap between numbers is 1, 2 or 3 in TypeScript

1 Answer

0 votes
function isArraySortedAndValidGap(arr: number[]) {
    if (arr.length < 2) return true;

    const increasing: boolean = arr[1] > arr[0];
    for (let i = 1; i < arr.length; ++i) {
        const diff: number = arr[i] - arr[i - 1];
        if (diff !== 1 && diff !== 2 && diff !== 3 && diff !== -1 && diff !== -2 && diff !== -3) {
            return false;
        }
        if ((increasing && diff <= 0) || (!increasing && diff >= 0)) {
            return false;
        }
    }
    
    return true;
}

const arr1: number[] = [1, 2, 3, 5, 8, 11, 14, 15];
if (isArraySortedAndValidGap(arr1)) {
    console.log("Array is sorted and has valid gaps");
} else {
    console.log("Array is not sorted or gaps are invalid");
}

const arr2: number[] = [15, 14, 11, 8, 5, 3, 2, 1];
if (isArraySortedAndValidGap(arr2)) {
    console.log("Array is sorted and has valid gaps");
} else {
    console.log("Array is not sorted or gaps are invalid");
}

 
 
/*
run:

"Array is sorted and has valid gaps" 
"Array is sorted and has valid gaps"
 
*/

 



answered Jan 12, 2025 by avibootz
...