蓝桥杯 基础练习 数列特征

蓝桥杯 基础练习 数列特征
时间限制: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.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];
		int sum = 0;
		for (int i = 0; i < n; i++) {
			arr[i] = sc.nextInt();
			sum += arr[i];
		}
		Arrays.sort(arr);
		if (n == 1) {
			System.out.println(arr[0]);
			System.out.println(arr[0]);
			System.out.println(arr[0]);
		} else {
			System.out.println(arr[n - 1]);
			System.out.println(arr[0]);
			System.out.println(sum);
		}

		sc.close();

	}

}

有一个陷阱:初始化sum=0, 如果只有一组负数数据,容易出错。
如果int arr[] = new int[n+1];这时候max = arr[n]

你可能感兴趣的:(蓝桥杯,数列特征,ACM)