考试错题
两道简单题硬是在考试的时候全部0分了,我好笨。
①遍历数组求最值 (20 分)
输入格式:
第一行给出一个n。
第二行给出数组a中的n个数。
输出格式:
输出数组元素的最大值和最小值,并返回去除最大最小值后的平均值(取小数点后两位)
输入样例:
10
9 0 1 0 0 1 0 0 6 -1
输出样例:
max=9
min=-1
avg=1.00
#include<stdio.h>
int main(){
int n;
scanf("%d",&n);
int str[n];
int max,maxx=0;
float sum=0;
int min,minn=0;
float avg;
for(int i=0;i<n;i++){
scanf("%d",&str[i]);
}
max=str[0];
min=str[0];
for(int j=0;j<n;j++){
if (str[j]>max){
max=str[j];
maxx=j;
}
if(str[j]<min){
min=str[j];
minn=j;
}
}
for(int k=0;k<n;k++){
sum=sum+str[k];
}
printf("sum=%f\n",sum);
sum=sum-str[minn]-str[maxx];
printf("sum=%f\n",sum);
printf("minn=%d\n",minn);
printf("maxx=%d\n",maxx);
printf("n=%d\n",n);
avg=sum/(n-2);
printf("max=%d\n",max);
printf("min=%d\n",min);
printf("avg=%.2f",avg);
return 0;
}
附一个用指针求最大值最小值的
#include<stdio.h>
void main()
{
double a[] = {3, 4.2, 4, 5.3, 1, 0.4, 5};
double *max=(double *)malloc(sizeof(double)); // 最大值指针
double *min=(double *)malloc(sizeof(double)); // 最小值指针
int i;
*max = a[0]; // 初始化最大值
*min = a[0]; // 初始化最小值
for(i=1; i<7; i++) // 7表示数组a的长度
{
if(*max<a[i])
*max = a[i]; // 保存最大值
if(*min>a[i])
*min = a[i]; // 保存最小值
}
}
②数组分段求和 (22 分)
编写一个函数,将数组a中的n个数每5个相邻的元素为一组分别求和(假设求和结果不溢出),结果放到数组b中,最后一组如果不足5个也进行求和。(题目保证数组a和b的长度不超过50)
输入格式:
第一行给出一个n。
第二行给出数组a中的n个数。
输出格式:
对数组a每5个相邻的元素为一组分别求和并输出,格式见样例。
输入样例:
输入数组a的元素。例如:
18
4 8 3 2 0 5 2 9 7 8 4 3 2 1 8 4 3 2
输出样例:
输出数组b的元素。例如:
b[0]=17
b[1]=31
b[2]=18
b[3]=9
#include <stdio.h>
int main()
{
int n,sum=0;
scanf("%d",&n);
int yu=n%5,turn=n;
if(yu){
n=n+(5-yu);
}
int str[n],b[n/5];
for(int i=0;i<n;i++){
if((i+1)<=turn){
scanf("%d",&str[i]);
}
if((i+1)>turn){
str[i]=0;
}
}
for(int j=0;j<(n/5);j++){
int sum2=0;
for(int i=j*5;i<5+j*5;i++){
sum2+=str[i];
}
printf("b[%d]=%d\n",j,sum2);
}
return 0;
}