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

51,940 answers

573 users

How to check if a sequence of numbers is an Arithmetic progression (consecutive differences are the same) in Java

2 Answers

0 votes
import java.util.Arrays;

public class SequenceIsArithmeticProgression_Java {
    public static boolean isArithmeticProgression(int[] arr) {
        int size = arr.length;
        if (size == 1) {
            return true;
        }

        Arrays.sort(arr);

        int difference = arr[1] - arr[0];
        for (int i = 2; i < size; i++) {
            if (arr[i] - arr[i - 1] != difference) {
                return false;
            }
        }

        return true;
    }

    public static void main(String[] args) {
        int[] arr = {10, 20, 15, 5, 25, 35, 30};

        System.out.println(isArithmeticProgression(arr) ? "Yes" : "No");
    }
}


/*
run:

Yes

*/

 



answered Sep 21, 2024 by avibootz
edited Sep 21, 2024 by avibootz
0 votes
import java.util.HashSet;

public class SequenceIsArithmeticProgression_Java {
    public static boolean isArithmeticProgression(int[] arr) {
        HashSet<Integer> set = new HashSet<Integer>();
        int size = arr.length;
        
        int max = Integer.MIN_VALUE;
        int min = Integer.MAX_VALUE;
        for (int i : arr) {
            max = Math.max(i, max);
            min = Math.min(i, min);
            set.add(i);
        }
        
        int difference = (max - min) / (size - 1);
        int count = 0;
 
        while (set.contains(max)) {
            count++;
            max = max - difference;
        }
        
        if (count == arr.length) {
            return true;
        }
 
        return false;
    }

    public static void main(String[] args) {
        int[] arr = {10, 20, 15, 5, 25, 35, 30};

        System.out.println(isArithmeticProgression(arr) ? "Yes" : "No");
    }
}


/*
run:

Yes

*/

 



answered Sep 21, 2024 by avibootz
...