题目描述
数学老师给小明出了一道等差数列求和的题目。但是粗心的小明忘记了一 部分的数列,只记得其中 NN 个整数。
现在给出这 NN 个整数,小明想知道包含这 NN 个整数的最短的等差数列有几项?
输入描述
输入的第一行包含一个整数 NN。
第二行包含 NN 个整数 A1,A2,⋅⋅⋅,ANA1,A2,⋅⋅⋅,AN。(注意 A1A1 ∼ ANAN 并不一定是按等差数列中的顺序给出)
其中,2≤N≤105,0≤Ai≤1092≤N≤105,0≤Ai≤109。
输出描述
输出一个整数表示答案。
输入输出样例
示例
输入
5
2 6 4 10 20
输出
10
import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
int[] arr=new int[n];
for (int i = 0; i < arr.length; i++) {
arr[i]=sc.nextInt();
}
Arrays.sort(arr);
int gcdNumber=arr[1]-arr[0];
for (int i=2;i<n;i++){
gcdNumber=gcd(gcdNumber,arr[i]-arr[i-1]);
}
if (gcdNumber==0){
System.out.println(n);
}else {
System.out.println((arr[n-1]-arr[0])/gcdNumber+1);
}
}
public static int gcd(int a,int b){
if (b==0){
return a;
}else {
return gcd(b, a%b);
}
}
}