试题 基础练习 数列特征
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
给出n个数,找出这n个数的最大值,最小值,和。
输入格式
第一行为整数n,表示数的个数。
第二行有n个数,为给定的n个数,每个数的绝对值都小于10000。
输出格式
输出三行,每行一个整数。第一行表示这些数中的最大值,第二行表示这些数中的最小值,第三行表示这些数的和。
样例输入
5
1 3 -2 4 5
样例输出
5
-2
11
数据规模与约定
1 <= n <= 10000。
两种方法:
方法一:用将输入的数保存到集合ArrayList中,用Collections.sort()进行排序。
import java.util.*;
public class Main {
public static void main(String []args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
ArrayList<Integer> list = new ArrayList<Integer>();
for(int i=0;i<n;i++) {
list.add(sc.nextInt());
}
Collections.sort(list);
System.out.println(list.get(list.size()-1));
System.out.println(list.get(0));
int sum=0;
for(int i:list) {
sum+=i;
}
System.out.println(sum);
}
}
方法二:将输入的数保存到数组中,设置三个变量,temp,max,min,用for循环比较出max和min并计算出和
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int max = -20000;
int min = 20000;
int sum = 0;
int n = sc.nextInt();
int arr[] = new int[n];
for (int i = 0; i < arr.length; i++) {
arr[i] = sc.nextInt();
}
for (int i = 0; i < arr.length; i++) {
sum = sum + arr[i];
if (max < arr[i]) {
max = arr[i];
}
if (min > arr[i]) {
min = arr[i];
}
}
System.out.println(max);
System.out.println(min);
System.out.println(sum);
}
}
扩展资料:
1.java中的Collections类
点击查看java中的Collections类相关知识点
2.foreach循环
使用foreach遍历格式如下
for(类型 ;对象)
{
循环语句
}
例如:foreach遍历数组
int arrays[3];
for(int array; arrays)
{
System.out.println(array);
}