偶数求和
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 29943 Accepted Submission(s): 12947
Problem Description
有一个长度为n(n<=100)的数列,该数列定义为从2开始的递增有序偶数,现在要求你按照顺序每m个数求出一个平均值,如果最后不足m个,则以实际数量求平均值。编程输出该平均值序列。
Input
输入数据有多组,每组占一行,包含两个正整数n和m,n和m的含义如上所述。
Output
对于每组输入数据,输出一个平均值序列,每组输出占一行。
Sample Input
3 2
4 2
Sample Output
3 6
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 29943 Accepted Submission(s): 12947
Problem Description
有一个长度为n(n<=100)的数列,该数列定义为从2开始的递增有序偶数,现在要求你按照顺序每m个数求出一个平均值,如果最后不足m个,则以实际数量求平均值。编程输出该平均值序列。
Input
输入数据有多组,每组占一行,包含两个正整数n和m,n和m的含义如上所述。
Output
对于每组输入数据,输出一个平均值序列,每组输出占一行。
Sample Input
3 2
4 2
Sample Output
3 6
3 7
#include <stdio.h>
int main(){
char b;
int n, m, i, a0, an, ave, t;
while ( ~scanf("%d%d", &n, &m) ){
t = n/m;
if ( n%m != 0 ){
b = 0;
for ( i=1; i<=t; ++i ){
a0 = ((i-1)*m+1)<<1;
an = ((i-1)*m+m)<<1;
ave = (a0+an)/2;
if ( b ){
printf(" ");
}
b = 1;
printf("%d", ave);
}
a0 = (t*m+1)<<1;
an = (n)<<1;
ave = (a0+an)/2;
if ( b ){
printf(" ");
}
printf("%d", ave);
printf("\n");
}
else {
for ( i=1; i<=t; ++i ){
a0 = ((i-1)*m+1)<<1;
an = ((i-1)*m+m)<<1;
ave = (a0+an)/2;
if ( i != 1 ){
printf(" ");
}
printf("%d", ave);
}
printf("\n");
}
}
return 0;
}
本文介绍了一道编程题,要求对从2开始的递增有序偶数序列按指定长度分段并计算每段的平均值。提供了完整的C语言代码实现。
984

被折叠的 条评论
为什么被折叠?



