杭電2011
996 ワード
多項式の和
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 38855 Accepted Submission(s): 22648
Problem Description
多項式の説明は以下の通りです:1-1/2+1/3-1/4+1/5-1/6+...この多項式の前のn項の和を求めてください.
Input
入力データは2行からなり、まず正の整数m(m<100)であり、試験例の個数を表し、2行目はm個の正の整数を含み、各整数(n,n<1000としてもよい)について、この多項式の前のn項の和を求める.
Output
各テストインスタンスnについては、多項式の前のn項の和を出力する必要があります.各テストインスタンスの出力は1行を占め、結果は2桁の小数を保持します.
Sample Input
Sample Output
コードは次のとおりです.
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 38855 Accepted Submission(s): 22648
Problem Description
多項式の説明は以下の通りです:1-1/2+1/3-1/4+1/5-1/6+...この多項式の前のn項の和を求めてください.
Input
入力データは2行からなり、まず正の整数m(m<100)であり、試験例の個数を表し、2行目はm個の正の整数を含み、各整数(n,n<1000としてもよい)について、この多項式の前のn項の和を求める.
Output
各テストインスタンスnについては、多項式の前のn項の和を出力する必要があります.各テストインスタンスの出力は1行を占め、結果は2桁の小数を保持します.
Sample Input
2
1 2
Sample Output
1.00
0.50
コードは次のとおりです.
#include <stdio.h>
#include <math.h>
#include <malloc.h>
int main ()
{
int m,i,n,j;
int *a;
double s=0;
scanf("%d",&m);
a=(int *)malloc(m*sizeof(int));
for (i=0; i<m; i++)
{
scanf("%d",&a[i]);
n=a[i];
s=0;
for (j=1; j<=n; j++)
s=s+pow(-1,j-1)*1/j;
printf("%.2lf
",s);
}
return 0;
}