蓝桥杯之数列特征

时间:2022-09-09 23:09:20

问题描述

给出n个数,找出这n个数的最大值,最小值,和。

输入格式

第一行为整数n,表示数的个数。

第二行有n个数,为给定的n个数,每个数的绝对值都小于10000。

输出格式
输出三行,每行一个整数。第一行表示这些数中的最大值,第二行表示这些数中的最小值,第三行表示这些数的和。
样例输入
5
1 3 -2 4 5
样例输出
5
-2
11
数据规模与约定
1 <= n <= 10000。
解题思路:输入第一个数字用来控制第二行的数组的长度,再将第二行输入的数组进行最大值和最小值的判断,并且叠加求和并且输出。
涉及知识点:1.C语言中,如何进行动态控制数组的长度;2.如何对数字进行求最值
代码:
#include<stdio.h>
int main(){
int n,i,j,max=-10001,min=10001,sum=0;//这一行数据很重要 
scanf("%d",&n);
int a[n];
for(i=0;i<n;i++){
scanf("%d",&a[i]);
}
for(i=0;i<n;i++){
max=(max<a[i])?a[i]:max;//这里运用的是选择表达式,是C语言中的唯一一个三目表达式
min=(min>a[i])?a[i]:min;
sum+=a[i];
}
printf("%d\n",max);
printf("%d\n",min);
printf("%d\n",sum);
return 0;

上述代码中之所以将max赋值为-10001,min赋值为10001,是因为题目中的要求的数字的范围是1到10000,为了保证数字能满足题目所给的内容符合输出要求,在比较的时候,max 的初值要比所有的数字都要小,min 的数字正好相反,要比所有的数字都要大,这样才能保证我们在输入数据的时候不会出现溢出的情况。