原题链接:偶数求和
解题思路:
有一个长度为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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复