偶数求和
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 105789 Accepted Submission(s): 43962
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
Author
lcy
Source
答案:
#include <stdio.h>
#include <stdlib.h>
void main()
{
int n,m;
int i,j;
int sign;
int sum;
while (~scanf("%d %d",&n,&m))
{
for (i=1;i<=n;)
{
sum = 0;
sign = 0;
for (j=1;j<=m&&i<=n;j++)
{
sum = sum + i*2;
sign++;
i++;
}
printf("%d",sum/sign);
if (i<=n)
printf(" ");
}
printf("\n");
}
}
这道题我写了三版,提交一直是Output Limit Exceeded,这是因为我在while循环中少些了~,由于文件要结束输入,while循环本应写为while (scanf("%d %d",&n,&m)!=EOF),其中EOF的值为-1,~表示按位取反,二进制按位取反,-1二进制按位取反后值为1,即输入值为0时,循环执行。