- 1. C语言8.7
给定两个一维数组,分别内含n个和m个学生的成绩,分别求出其平均成绩并输出。
【输入形式】
第一行有两个用空格隔开的整数n和m,表示分别有n个和m个学生。
第二行有n个用空格隔开的实数,表示n个学生的成绩。
第三行有m个用空格隔开的实数,表示m个学生的成绩。
保证n和m均不超过50,且所有成绩大于等于0且小于等于100。
【输出形式】
两个用空格隔开的实数,分别为第一组的n个学生和第二组的m个学生的平均成绩,小数点后保留2位小数。
请注意行尾输出换行。
【样例输入】
10 5
100 56 78 98.5 76 87 99 67.5 75 97
98 85 79 80.5 99.5
【样例输出】
83.40 88.40
#include <stdio.h>
int main()
{
int i,m,n,j;
double a[60],b[60],sum1,sum2;
scanf("%d" "%d",&n,&m);
for(sum1=0,i=0;i<n;i++)
{
scanf("%lf",&a[i]);
sum1=sum1+a[i];
}
for(sum2=0,j=0;j<n;j++)
{
scanf("%lf",&b[j]);
sum2=sum2+b[j];
}
printf("%.2f %.2f\n",sum1/n,sum2/m);
return 0;
}
- 2. 【数组基础】C语言程序设计教程(第三版)课后习题7.5
输入10个数字,然后逆序输出。
【输入形式】
十个整数
【输出形式】
逆序输出,空格分开
【样例输入】
1 2 3 4 5 6 7 8 9 0
【样例输出】
0 9 8 7 6 5 4 3 2 1
【提示】
数组?堆栈?
#include <stdio.h>
#define n 10
int main()
{
int i;
int arr[10];
for(i=0;i<10;i++)
{
scanf("%d ",&arr[i]);
}
for(i=9;i>=0;i--)
{
printf("%d ",arr[i]);
}
return 0;
}
- 3. 【数组基础】【插入】C语言程序设计教程(第三版)课后习题7.4
已有一个已排好的9个元素的数组,今输入一个数要求按原来排序的规律将它插入数组中。
【输入形式】
第一行,原始数列。 第二行,需要插入的数字。
【输出形式】
排序后的数列
【样例输入】
1 7 8 17 23 24 59 62 101
50
【样例输出】
1
7
8
17
23
24
50
59
62
101
#include <stdio.h>
int main()
{
int arr[10];
int n,i,j;
for(i=0;i<9;i++)
{
scanf("%d", &arr[i]);
}
scanf("%d",&n);
for(i=8;i>=0;i--)
{
if(n<arr[i])
arr[i+1]=arr[i];
else
break;
}
arr[i+1]=n;
for(i=0;i<10;i++)
printf("%d\n",arr[i]);
}
- 4. 计算一个数组中超过平均数的元素数量。
【问题描述】
计算一个数组中超过平均数的元素数量。
【输入形式】
空格分隔的10个整数。
【输出形式】
空格分割的10个整数。
【样例输入】
1 2 3 4 5 6 7 8 9 10
【样例输出】
5
【样例说明】
【评分标准】
#include <stdio.h>
int main()
{
int a[10];
int count=0,i,j;
double pj,sum=0;
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
sum=sum+a[i];
}
pj=sum/10;
for(j=0;j<10;j++)
{
if(a[j]>pj)
{
count=count+1;
}
}
printf("%d",count);
return 0;
}
- 5. 使用一维数组逆序后输出奇数位元素
【问题描述】输入一个正整数n,再输入n个整数,存入数组a中,先将数组a中的这n个数逆序存放,再按顺序输出数组a中的下标为奇数的元素。试编写程序。
【输入形式】输入一个正整数n,再输入n个整数
【输出形式】数组a中的下标为奇数的元素(两数之间空一格)
【样例输入】5
1 2 3 4 5
【样例输出】4 2
【样例说明】
【评分标准】
#include <stdio.h>
int main()
{
int n,i;
scanf("%d",&n);
int arr[n];
for(i=n-1;i>=0;i--)
{
scanf("%d",&arr[i]);
}
for(i=1;i<n;i++)
{
if(i%2!=0)
printf("%d ",arr[i]);
}
return 0;
}
- 6. 使用一维数组求平均值、中位数和众数
【问题描述】编程计算一个整型数组中元素(假设元素值的范围为0-10)的平均值、中位数和众数。中位数指的是排列在数组中间的数(注意,这里中间位置是在原始数组的中间位置,不需要对数组排序),如果原始数据的个数是偶数,那么中位数等于中间那两个元素的算术平均值。众数是数组中出现次数最多的那个数。
【输入形式】输入20个整数
【输出形式】输出这20个数的平均值、中位数、众数
【样例输入】5 4 4 2 3 3 1 5 4 3 3 4 2 1 5 5 2 4 3 3
【样例输出】aver=3.30,median=3.00,mode=3
【样例说明】平均值保留2位小数,中位数保留2位小数。
【评分标准】
#include <stdio.h>
int main()
{
int a[20],i,maxcount=0;
float aver,median;
int mode=0;
float sum=0.00;
int count[11]={0};
for(i=0;i<20;i++)
{
scanf("%d",&a[i]);
sum=sum+a[i];
count[a[i]]++;
}
for(i=0;i<11;i++)
{
if(maxcount<count[i])
{
maxcount=count[i];
mode=i;
}
}
aver=sum/20;
median=(a[10]+a[9])/2;
printf("aver=%.2f,median=%.2f,mode=%d",aver,median,mode);
return 0;
}
- 7. 按奇偶性重排数组
【问题描述】将数组中的奇数排在数组前半部,偶数排在数组后半部。
【输入形式】数组元素个数 数组各元素值
【输出形式】调整位置之后的各数组元素,元素之间以一个空格分割
【样例输入】4
5 6 8 3
【样例输出】5 3 6 8
【样例说明】
【评分标准】
#include <stdio.h>
int main()
{
int n,i;
int a[n];
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
for(i=0;i<n;i++)
{
if(a[i]%2!=0)
{
printf("%d ",a[i]);
}
}
for(i=0;i<n;i++)
{
if(a[i]%2==0)
{
printf("%d ",a[i]);
}
}
return 0;
}