原题链接:偶数求和
解题思路:
有一个长度为n(n<=100)的数列,该数列定义为从2开始的递增有序偶数(公差为2的等差数列),现在要求你按照顺序每m个数求出一个平均值,如果最后不足m个,则以实际数量求平均值。编程输出该平均值序列。
按照顺序每m个数求出一个平均值:什么意思呢?如果 n%m!=0 怎么办,最后一组是选择以m为除数,还是n%m为除数呢?根据题目以及示例,选择后者。
注意事项:
1.输入数据有多组:以EOF结束
2.每组输出占一行:换行
参考代码:
#include <stdio.h>
int avg(int* p,int srt,int end)
{
int num=0,sum=0,avg;
int i;
for ( i=srt; i<=end; i++ )
if ( *(p+i) )
{
num++;
sum+=*(p+i);
}
return sum/num;
}
int main()
{
int n,m;
while ( scanf("%d %d",&n,&m)!=EOF )
{
int a[101]={0},begin=2,k;
for ( k=1; k<=n; k++,begin+=2 )
a[k]=begin;
int i,j;
for ( i=1,j=m; i<=n; i+=m,j+=m )
printf("%d ",avg(a,i,j));
printf("\n");
}
}0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复