数列特征
蓝桥杯基础练习
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
给出n个数,找出这n个数的最大值,最小值,和。
输入格式
第一行为整数n,表示数的个数。
第二行有n个数,为给定的n个数,每个数的绝对值都小于10000。
输出格式
输出三行,每行一个整数。第一行表示这些数中的最大值,第二行表示这些数中的最小值,第三行表示这些数的和。
样例输入
5
1 3 -2 4 5
样例输出
5
-2
11
数据规模与约定
1 <= n <= 10000。
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<n;i++) {
int a =sc.nextInt();
arr[i] =a;
}
System.out.println(Max(arr));
System.out.println(Min(arr));
System.out.println(Sum(arr));
}
/**
* 最大值
* @param arr 传进的数组参数
* @return 最大值
*/
public static int Max(int[] arr) {
for(int i = 0;i<arr.length-1;i++) {
if(arr[i]>arr[i+1]) {
int temp = arr[i];
arr[i] = arr[i+1];
arr[i+1] = temp;
}
}
return arr[arr.length-1];
}
/**
* 求最小值
* @param arr 传进来的数组
* @return 最小值
*/
public static int Min(int[] arr) {
for(int i = 0;i<arr.length-1;i++) {
if(arr[i]<arr[i+1]) {
int temp = arr[i];
arr[i] = arr[i+1];
arr[i+1] = temp;
}
}
return arr[arr.length-1];
}
public static int Sum(int[] arr) {
int sum = 0;
for(int i = 0;i < arr.length;i++) {
sum += arr[i];
}
return sum;
}
}