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,923 questions

51,856 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 Java

1 Answer

0 votes
public class Main {

    public static boolean isArraySortedAndValidGap(int[] arr) {
        if (arr == null || arr.length < 2) {
            return false;
        }

        boolean isIncreasing = arr[1] > arr[0];
        for (int i = 1; i < arr.length; i++) {
            int gap = Math.abs(arr[i] - arr[i - 1]);
            if (gap < 1 || gap > 3) {
                return false;
            }
            if (isIncreasing && arr[i] <= arr[i - 1]) {
                return false;
            }
            if (!isIncreasing && arr[i] >= arr[i - 1]) {
                return false;
            }
        }
        
        return true;
    }

    public static void main(String[] args) {
        int[] array1 = {1, 2, 3, 5, 8, 11, 14, 15};
        int[] array2 = {15, 14, 11, 8, 5, 3, 2, 1};
        int[] array3 = {1, 2, 3, 5, 8, 110, 14, 15};

        System.out.println(isArraySortedAndValidGap(array1)); 
        System.out.println(isArraySortedAndValidGap(array2)); 
        System.out.println(isArraySortedAndValidGap(array3)); 
    }
}



/*
run:
 
true
true
false
 
*/

 



answered Jan 12, 2025 by avibootz
...