资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
给出n个数,找出这n个数的最大值,最小值,和。
输入格式
第一行为整数n,表示数的个数。
第二行有n个数,为给定的n个数,每个数的绝对值都小于10000。
输出格式
输出三行,每行一个整数。第一行表示这些数中的最大值,第二行表示这些数中的最小值,第三行表示这些数的和。
样例输入
5
1 3 -2 4 5
样例输出
5
-2
11
数据规模与约定
1 <= n <= 10000。
解题思路:该题就是变形版的冒泡排序法,用冒泡排序将一个数列排好之后,头和尾就分别是最大和最小
代码奉上:
package blue;
import java.util.Scanner;
public class BASIC_4 {
public static void main(String[] args)
{
Scanner in=new Scanner(System.in);
int n=in.nextInt();
int[] arr=new int[n];
for(int i=0;i<n;i++)
{
arr[i]=in.nextInt();
}
int he=0;
//排序
for(int i=0;i<n;i++)
{
for(int j=0;j<n-i-1;j++)
{
if(arr[j]>arr[j+1])
{
int a=0;
a=arr[j];
arr[j]=arr[j+1];
arr[j+1]=a;
}
}
}
//输出
for(int i=0;i<n;i++)
{
he=arr[i]+he;
}
System.out.println(arr[n-1]);
System.out.println(arr[0]);
System.out.println(he);
}
}