hdu2015 偶数求和

来源:互联网 发布:武极天下阵法进阶数据 编辑:程序博客网 时间:2024/04/30 14:20
Problem Description
有一个长度为n(n<=100)的数列,该数列定义为从2开始的递增有序偶数,现在要求你按照顺序每m个数求出一个平均值,如果最后不足m个,则以实际数量求平均值。编程输出该平均值序列。
 

Input
输入数据有多组,每组占一行,包含两个正整数n和m,n和m的含义如上所述。
 

Output
对于每组输入数据,输出一个平均值序列,每组输出占一行。
 

Sample Input
3 24 2
 
Sample Output
3 63 7

源代码:

#include<stdio.h>
int main()
{
    int m,n,i,p,q,b[110];
    while(scanf("%d%d",&n,&m)!=EOF)
    {
        p=n/m;
        q=n%m;
        if(p!=0&&q==0)
        {
             b[0]=m+1;
             for(i=1;i<p;i++)
             b[i]=b[i-1]+2*m;
        }
        else
        if(p!=0&&q!=0)
        {
             b[0]=m+1;
             for(i=1;i<p;i++)
             b[i]=b[i-1]+2*m;
             if(q>1)
             b[p]=m*(2*p*m+q+1);
             else if(q=1)
             b[p]=2*(p*m+1);
        }
        else
        if(p==0)
        b[0]=m*(m+1);
        if(q!=0)
        {
            for(i=0;i<p;i++)
            printf("%d ",b[i]);
            printf("%d\n",b[p]);
        }
        else
        {
            for(i=0;i<p-1;i++)
            printf("%d ",b[i]);
            printf("%d\n",b[p-1]);
        }
    }
return 0;
}

0 0
原创粉丝点击