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<iostream>
- #include<string.h>
- using namespace std;
- int main()
- {
- int a[500],i,m,n,t,s1,s;
- while(cin>>n>>m)
- {
- s=s1=0;
- memset(a,0,sizeof(a));
- for(i=1;i<=n;i++)
- a[i]=2*i;
- t=n%m;
- for(i=1;i<=n-t;i++)
- {
- s+=a[i];
- if(i%m==0&&i==m)//判断是否是第一个输出的数,若是不输出“空格”
- {
- cout<<s/m;
- s=0;
- }
- else if(i%m==0&&i!=m)
- {
- cout<<" "<<s/m;
- s=0;
- }
- }
- if(t)//判断是否有余数,若有才进行求平均值后输出。
- {
- for(i=n;i>n-t;i--)
- s1+=a[i];
- cout<<" "<<s1/t;
- }
- cout<<endl;
- }
- return 0;
- }