【卡雷尔杯】等差数列

import java.util.Arrays;
import java.util.Scanner;

//等差数列–1
public class Test01 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print(“请输入N个整数的N值:”);
int N = sc.nextInt();
int[] arr = new int[N];
//遍历数组,用来存储N个值
for (int i = 0; i < arr.length; i++) {
System.out.print(“第” + (i + 1) + “个数的值为”);
arr[i] = sc.nextInt();
}
//给数组进行排序
Arrays.sort(arr);
int[] arrReduce = new int[N - 1]; //用来记录两相邻数之差
//取相邻两数的差值,记录到arrReduce数组中
for (int i = 0; i < arr.length; i++) {
if (arr.length - 1 <= i) {//防止索引越界异常
break;
}
arrReduce[i] = arr[i + 1] - arr[i];
}
//获取差值最小的那个数,即为等差数列的d
Arrays.sort(arrReduce);
int d = arrReduce[0]; //用来存储d
int minNum = arr[0]; //用来存储数组的最小值
int maxNum = arr[arr.length - 1]; //用来存储数组的最大值
int[] minArr = new int[(maxNum - minNum) / d + 1]; //等差数列最小的数组
for (int i = 0; i < minArr.length; i++) {
//对这个最小的等差数列数组进行赋值
minArr[i] = minNum + i * d;
}
//遍历打印这个最小的等差数列
for (int i = 0; i < minArr.length; i++) {
System.out.print(minArr[i] + " ");
}
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值