试题 基础练习 数列特征
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
给出n个数,找出这n个数的最大值,最小值,和。
输入格式
第一行为整数n,表示数的个数。
第二行有n个数,为给定的n个数,每个数的绝对值都小于10000。
输出格式
输出三行,每行一个整数。第一行表示这些数中的最大值,第二行表示这些数中的最小值,第三行表示这些数的和。
样例输入
5
1 3 -2 4 5
样例输出
5
-2
11
数据规模与约定
1 <= n <= 10000。
代码实现部分 (C语言实现)
#include <stdio.h>
#include <stdlib.h>
int main (void)
{
int n,maxn,minn;
//注意数据规模
long long sum;
int i;
int a[10000];
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
sum=minn=maxn=a[0];
for(i=1;i<n;i++)
{
sum=sum+a[i];
if(a[i]>maxn)
maxn=a[i];
/*error*
else
minn=a[j];
*/
if(a[i]<minn)
minn=a[i];
}
printf("%d\n",maxn);
printf("%d\n",minn);
//输出格式
printf("%I64d\n",sum);
return 0;
}
这个题目虽然不难,但是还是具有一定的学习指导意义,需要注意的地方已经在代码部分做了标识。
1.考虑到数据规模的问题,要对数据类型加以判断,数据之和类型要用long long类型,输出格式为printf("%I64d\n",x);
2.进行条件判断时的错误,目前还不知道为什么不正确,希望明白的人给我留言,不甚感谢。
错误代码
for(i=1;i<n;i++)
{
sum=sum+a[i];
if(a[i]>maxn)
maxn=a[i];
else
minn=a[j];
}
改成如下提交正确
for(i=1;i<n;i++)
{
sum=sum+a[i];
if(a[i]>maxn)
maxn=a[i];
[i]<minn)
minn=a[i];
}